mirror of
				https://github.com/louislam/uptime-kuma.git
				synced 2025-10-25 15:59:20 +08:00 
			
		
		
		
	Merge branch 'master' into restructure-status-page
This commit is contained in:
		
							
								
								
									
										6
									
								
								.github/PULL_REQUEST_TEMPLATE.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.github/PULL_REQUEST_TEMPLATE.md
									
									
									
									
										vendored
									
									
								
							| @@ -4,10 +4,10 @@ Fixes #(issue) | ||||
|  | ||||
| ## Type of change | ||||
|  | ||||
| Please delete options that are not relevant. | ||||
| Please delete any options that are not relevant. | ||||
|  | ||||
| - Bug fix (non-breaking change which fixes an issue) | ||||
| - User Interface | ||||
| - User interface (UI) | ||||
| - New feature (non-breaking change which adds functionality) | ||||
| - Breaking change (fix or feature that would cause existing functionality to not work as expected) | ||||
| - Translation update | ||||
| @@ -18,7 +18,7 @@ Please delete options that are not relevant. | ||||
|  | ||||
| - [ ] My code follows the style guidelines of this project | ||||
| - [ ] I ran ESLint and other linters for modified files | ||||
| - [ ] I have performed a self-review of my own code and test it | ||||
| - [ ] I have performed a self-review of my own code and tested it | ||||
| - [ ] I have commented my code, particularly in hard-to-understand areas | ||||
| - [ ] My changes generate no new warnings | ||||
| - [ ] My code needed automated testing. I have added them (this is optional task) | ||||
|   | ||||
							
								
								
									
										26
									
								
								.github/workflows/close-incorrect-issue.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										26
									
								
								.github/workflows/close-incorrect-issue.yml
									
									
									
									
										vendored
									
									
										Normal file
									
								
							| @@ -0,0 +1,26 @@ | ||||
|  | ||||
| name: Close Incorrect Issue | ||||
|  | ||||
| on: | ||||
|   issues: | ||||
|     types: [opened] | ||||
|  | ||||
| jobs: | ||||
|   close-incorrect-issue: | ||||
|     runs-on: ${{ matrix.os }} | ||||
|  | ||||
|     strategy: | ||||
|       matrix: | ||||
|         os: [ubuntu-latest] | ||||
|         node-version: [16.x] | ||||
|  | ||||
|     steps: | ||||
|     - uses: actions/checkout@v2 | ||||
|  | ||||
|     - name: Use Node.js ${{ matrix.node-version }} | ||||
|       uses: actions/setup-node@v2 | ||||
|       with: | ||||
|         node-version: ${{ matrix.node-version }} | ||||
|         cache: 'npm' | ||||
|     - run: npm ci | ||||
|     - run: node extra/close-incorrect-issue.js ${{ secrets.GITHUB_TOKEN }} ${{ github.event.issue.number }} ${{ github.event.issue.user.login }} | ||||
							
								
								
									
										4
									
								
								.github/workflows/stale-bot.yml
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								.github/workflows/stale-bot.yml
									
									
									
									
										vendored
									
									
								
							| @@ -15,8 +15,8 @@ jobs: | ||||
|           close-issue-message: 'This issue was closed because it has been stalled for 7 days with no activity.' | ||||
|           close-pr-message: 'This PR was closed because it has been stalled for 7 days with no activity.' | ||||
|           days-before-stale: 180 | ||||
|           days-before-close: 7 | ||||
|           days-before-close: 0 | ||||
|           exempt-issue-labels: 'News,Medium,High,discussion,bug,doc,' | ||||
|           exempt-pr-labels: 'awaiting-approval,work-in-progress,enhancement,' | ||||
|           exempt-pr-labels: 'awaiting-approval,work-in-progress,enhancement,feature-request' | ||||
|           exempt-issue-assignees: 'louislam' | ||||
|           exempt-pr-assignees: 'louislam' | ||||
|   | ||||
| @@ -27,9 +27,20 @@ The frontend code build into "dist" directory. The server (express.js) exposes t | ||||
|  | ||||
| ## Can I create a pull request for Uptime Kuma? | ||||
|  | ||||
| Generally, if the pull request is working fine, and it does not affect any existing logic, workflow and performance, I will merge into the master branch once it is tested. | ||||
| ⚠️ 2022-03-02 Update: | ||||
|  | ||||
| If you are not sure whether I will accept your pull request, feel free to create an empty pull request draft first. | ||||
| Since I found that merging pull requests is a pretty heavy task for me, I try to rearrange it. | ||||
|  | ||||
| ✅ Accept: | ||||
| - Bug/Security fix | ||||
| - Translations | ||||
| - Adding notification providers | ||||
|  | ||||
| ❌ Avoid: | ||||
| - Large pull requests | ||||
| - New big features | ||||
|  | ||||
| My long story here: https://www.reddit.com/r/UptimeKuma/comments/t1t6or/comment/hynyijx/ | ||||
|  | ||||
| ### Recommended Pull Request Guideline | ||||
|  | ||||
| @@ -43,42 +54,6 @@ If you are not sure whether I will accept your pull request, feel free to create | ||||
| 1. Write a proper description | ||||
| 1. Click "Change to draft" | ||||
|  | ||||
| ### Pull Request Examples | ||||
|  | ||||
| Here are some example situations in the past. | ||||
|  | ||||
| #### ✅ High - Medium Priority | ||||
|  | ||||
| Easy to review, no breaking change and not touching the existing code | ||||
|  | ||||
| - Add a new notification | ||||
| - Add a chart | ||||
| - Fix a bug | ||||
| - Translations | ||||
| - Add a independent new feature | ||||
|  | ||||
| #### *️⃣ Requires one more reviewer | ||||
|  | ||||
| I do not have such knowledge to test it. | ||||
|  | ||||
| - Add k8s supports | ||||
|  | ||||
| #### ⚠ Low Priority - Harsh Mode | ||||
|  | ||||
| Some pull requests are required to modify the core. To be honest, I do not want anyone to try to do that, because it would spend a lot of your time. I will review your pull request harshly. Also, you may need to write a lot of unit tests to ensure that there is no breaking change. | ||||
|  | ||||
| - Touch large parts of code of any very important features | ||||
| - Touch monitoring logic | ||||
| - Drop a table or drop a column for any reason | ||||
| - Touch the entry point of Docker or Node.js | ||||
| - Modify auth | ||||
|  | ||||
| #### *️⃣ Low Priority | ||||
|  | ||||
| It changed my current workflow and require further studies. | ||||
|  | ||||
| - Change my release approach | ||||
|  | ||||
| #### ❌ Won't Merge | ||||
|  | ||||
| - Any breaking changes | ||||
| @@ -227,7 +202,7 @@ https://github.com/louislam/uptime-kuma/issues?q=sort%3Aupdated-desc | ||||
| 1. `npm run build-docker` | ||||
| 1. `git push` | ||||
| 1. Publish the release note as 1.X.X  | ||||
| 1. `npm run upload-artifacts` | ||||
| 1. `npm run upload-artifacts` with env vars VERSION=1.X.X;GITHUB_TOKEN=XXXX | ||||
| 1. SSH to demo site server and update to 1.X.X | ||||
|  | ||||
| Checking: | ||||
|   | ||||
							
								
								
									
										10
									
								
								README.md
									
									
									
									
									
								
							
							
						
						
									
										10
									
								
								README.md
									
									
									
									
									
								
							| @@ -89,6 +89,12 @@ Project Plan: | ||||
|  | ||||
| https://github.com/louislam/uptime-kuma/projects/1 | ||||
|  | ||||
| ## ❤️ Sponsors | ||||
|  | ||||
| Thank you so much! (GitHub Sponsors will be updated manually. OpenCollective sponsors will be updated automatically, the list will be cached by GitHub though. It may need some time to be updated) | ||||
|  | ||||
| <img src="https://uptime.kuma.pet/sponsors?v=3" alt /> | ||||
|  | ||||
| ## 🖼 More Screenshots | ||||
|  | ||||
| Light Mode: | ||||
| @@ -109,7 +115,7 @@ Telegram Notification Sample: | ||||
|  | ||||
| ## Motivation | ||||
|  | ||||
| * I was looking for a self-hosted monitoring tool like "Uptime Robot", but it is hard to find a suitable one. One of the close ones is statping. Unfortunately, it is not stable and unmaintained. | ||||
| * I was looking for a self-hosted monitoring tool like "Uptime Robot", but it is hard to find a suitable one. One of the close ones is statping. Unfortunately, it is not stable and no longer maintained. | ||||
| * Want to build a fancy UI. | ||||
| * Learn Vue 3 and vite.js. | ||||
| * Show the power of Bootstrap 5. | ||||
| @@ -138,4 +144,4 @@ If you want to translate Uptime Kuma into your language, please read: https://gi | ||||
|  | ||||
| If you want to modify Uptime Kuma, this guideline may be useful for you: https://github.com/louislam/uptime-kuma/blob/master/CONTRIBUTING.md | ||||
|  | ||||
| English proofreading is needed too because my grammar is not that great, sadly. Feel free to correct my grammar in this README, source code, or wiki. | ||||
| Unfortunately, English proofreading is needed too because my grammar is not that great. Feel free to correct my grammar in this README, source code, or wiki. | ||||
|   | ||||
| @@ -4,5 +4,5 @@ WORKDIR /app | ||||
|  | ||||
| # Install apprise, iputils for non-root ping, setpriv | ||||
| RUN apk add --no-cache iputils setpriv dumb-init python3 py3-cryptography py3-pip py3-six py3-yaml py3-click py3-markdown py3-requests py3-requests-oauthlib && \ | ||||
|     pip3 --no-cache-dir install apprise==0.9.6 && \ | ||||
|     pip3 --no-cache-dir install apprise==0.9.7 && \ | ||||
|     rm -rf /root/.cache | ||||
|   | ||||
| @@ -8,5 +8,5 @@ WORKDIR /app | ||||
| RUN apt update && \ | ||||
|     apt --yes --no-install-recommends install python3 python3-pip python3-cryptography python3-six python3-yaml python3-click python3-markdown python3-requests python3-requests-oauthlib \ | ||||
|         sqlite3 iputils-ping util-linux dumb-init && \ | ||||
|     pip3 --no-cache-dir install apprise==0.9.6 && \ | ||||
|     pip3 --no-cache-dir install apprise==0.9.7 && \ | ||||
|     rm -rf /var/lib/apt/lists/* | ||||
|   | ||||
							
								
								
									
										57
									
								
								extra/close-incorrect-issue.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										57
									
								
								extra/close-incorrect-issue.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,57 @@ | ||||
| const github = require("@actions/github"); | ||||
|  | ||||
| (async () => { | ||||
|     try { | ||||
|         const token = process.argv[2]; | ||||
|         const issueNumber = process.argv[3]; | ||||
|         const username = process.argv[4]; | ||||
|  | ||||
|         const client = github.getOctokit(token).rest; | ||||
|  | ||||
|         const issue = { | ||||
|             owner: "louislam", | ||||
|             repo: "uptime-kuma", | ||||
|             number: issueNumber, | ||||
|         }; | ||||
|  | ||||
|         const labels = ( | ||||
|             await client.issues.listLabelsOnIssue({ | ||||
|                 owner: issue.owner, | ||||
|                 repo: issue.repo, | ||||
|                 issue_number: issue.number | ||||
|             }) | ||||
|         ).data.map(({ name }) => name); | ||||
|  | ||||
|         if (labels.length === 0) { | ||||
|             console.log("Bad format here"); | ||||
|  | ||||
|             await client.issues.addLabels({ | ||||
|                 owner: issue.owner, | ||||
|                 repo: issue.repo, | ||||
|                 issue_number: issue.number, | ||||
|                 labels: ["invalid-format"] | ||||
|             }); | ||||
|  | ||||
|             // Add the issue closing comment | ||||
|             await client.issues.createComment({ | ||||
|                 owner: issue.owner, | ||||
|                 repo: issue.repo, | ||||
|                 issue_number: issue.number, | ||||
|                 body: `@${username}: Hello! :wave:\n\nThis issue is being automatically closed because it does not follow the issue template. Please DO NOT open a blank issue.` | ||||
|             }); | ||||
|  | ||||
|             // Close the issue | ||||
|             await client.issues.update({ | ||||
|                 owner: issue.owner, | ||||
|                 repo: issue.repo, | ||||
|                 issue_number: issue.number, | ||||
|                 state: "closed" | ||||
|             }); | ||||
|         } else { | ||||
|             console.log("Pass!"); | ||||
|         } | ||||
|     } catch (e) { | ||||
|         console.log(e); | ||||
|     } | ||||
|  | ||||
| })(); | ||||
| @@ -20,7 +20,7 @@ if (sslKey && sslCert) { | ||||
| // Dual-stack support for (::) | ||||
| let hostname = process.env.UPTIME_KUMA_HOST; | ||||
|  | ||||
| // Also read HOST if not FreeBSD, as HOST is a system environment variable in FreeBSD | ||||
| // Also read HOST if not *BSD, as HOST is a system environment variable in FreeBSD | ||||
| if (!hostname && !FBSD) { | ||||
|     hostname = process.env.HOST; | ||||
| } | ||||
|   | ||||
							
								
								
									
										2873
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										2873
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										27
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										27
									
								
								package.json
									
									
									
									
									
								
							| @@ -1,6 +1,6 @@ | ||||
| { | ||||
|     "name": "uptime-kuma", | ||||
|     "version": "1.11.1", | ||||
|     "version": "1.12.1", | ||||
|     "license": "MIT", | ||||
|     "repository": { | ||||
|         "type": "git", | ||||
| @@ -27,16 +27,16 @@ | ||||
|         "jest-backend": "cross-env TEST_BACKEND=1 jest --config=./config/jest-backend.config.js", | ||||
|         "tsc": "tsc", | ||||
|         "vite-preview-dist": "vite preview --host --config ./config/vite.config.js", | ||||
|         "build-docker": "npm run build-docker-debian && npm run build-docker-alpine", | ||||
|         "build-docker": "npm run build && npm run build-docker-debian && npm run build-docker-alpine", | ||||
|         "build-docker-alpine-base": "docker buildx build -f docker/alpine-base.dockerfile --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/uptime-kuma:base-alpine . --push", | ||||
|         "build-docker-debian-base": "docker buildx build -f docker/debian-base.dockerfile --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/uptime-kuma:base-debian . --push", | ||||
|         "build-docker-alpine": "docker buildx build -f docker/dockerfile-alpine --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/uptime-kuma:alpine -t louislam/uptime-kuma:1-alpine -t louislam/uptime-kuma:1.11.1-alpine --target release . --push", | ||||
|         "build-docker-debian": "docker buildx build -f docker/dockerfile --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/uptime-kuma -t louislam/uptime-kuma:1 -t louislam/uptime-kuma:1.11.1 -t louislam/uptime-kuma:debian -t louislam/uptime-kuma:1-debian -t louislam/uptime-kuma:1.11.1-debian --target release . --push", | ||||
|         "build-docker-nightly": "docker buildx build -f docker/dockerfile --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/uptime-kuma:nightly --target nightly . --push", | ||||
|         "build-docker-alpine": "docker buildx build -f docker/dockerfile-alpine --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/uptime-kuma:alpine -t louislam/uptime-kuma:1-alpine -t louislam/uptime-kuma:1.12.1-alpine --target release . --push", | ||||
|         "build-docker-debian": "docker buildx build -f docker/dockerfile --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/uptime-kuma -t louislam/uptime-kuma:1 -t louislam/uptime-kuma:1.12.1 -t louislam/uptime-kuma:debian -t louislam/uptime-kuma:1-debian -t louislam/uptime-kuma:1.12.1-debian --target release . --push", | ||||
|         "build-docker-nightly": "npm run build && docker buildx build -f docker/dockerfile --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/uptime-kuma:nightly --target nightly . --push", | ||||
|         "build-docker-nightly-alpine": "docker buildx build -f docker/dockerfile-alpine --platform linux/amd64,linux/arm64,linux/arm/v7 -t louislam/uptime-kuma:nightly-alpine --target nightly . --push", | ||||
|         "build-docker-nightly-amd64": "docker buildx build -f docker/dockerfile --platform linux/amd64 -t louislam/uptime-kuma:nightly-amd64 --target nightly . --push --progress plain", | ||||
|         "upload-artifacts": "docker buildx build -f docker/dockerfile --platform linux/amd64 -t louislam/uptime-kuma:upload-artifact --build-arg VERSION --build-arg GITHUB_TOKEN --target upload-artifact . --progress plain", | ||||
|         "setup": "git checkout 1.11.1 && npm ci --production && npm run download-dist", | ||||
|         "setup": "git checkout 1.12.1 && npm ci --production && npm run download-dist", | ||||
|         "download-dist": "node extra/download-dist.js", | ||||
|         "update-version": "node extra/update-version.js", | ||||
|         "mark-as-nightly": "node extra/mark-as-nightly.js", | ||||
| @@ -61,7 +61,7 @@ | ||||
|         "@louislam/sqlite3": "~6.0.1", | ||||
|         "@popperjs/core": "~2.10.2", | ||||
|         "args-parser": "~1.3.0", | ||||
|         "axios": "~0.21.4", | ||||
|         "axios": "~0.26.0", | ||||
|         "bcryptjs": "~2.4.3", | ||||
|         "bootstrap": "5.1.3", | ||||
|         "bree": "~7.1.0", | ||||
| @@ -89,15 +89,15 @@ | ||||
|         "prometheus-api-metrics": "~3.2.0", | ||||
|         "qrcode": "~1.5.0", | ||||
|         "redbean-node": "0.1.3", | ||||
|         "socket.io": "~4.2.0", | ||||
|         "socket.io-client": "~4.2.0", | ||||
|         "socket.io": "~4.4.1", | ||||
|         "socket.io-client": "~4.4.1", | ||||
|         "tar": "^6.1.11", | ||||
|         "tcp-ping": "~0.1.1", | ||||
|         "thirty-two": "~1.0.2", | ||||
|         "timezones-list": "~3.0.1", | ||||
|         "v-pagination-3": "~0.1.7", | ||||
|         "vue": "next", | ||||
|         "vue-chart-3": "~0.5.11", | ||||
|         "vue-chart-3": "3.0.9", | ||||
|         "vue-confirm-dialog": "~1.0.2", | ||||
|         "vue-contenteditable": "~3.0.4", | ||||
|         "vue-i18n": "~9.1.9", | ||||
| @@ -109,6 +109,7 @@ | ||||
|         "vuedraggable": "~4.1.0" | ||||
|     }, | ||||
|     "devDependencies": { | ||||
|         "@actions/github": "~5.0.0", | ||||
|         "@babel/eslint-parser": "~7.15.8", | ||||
|         "@babel/preset-env": "^7.15.8", | ||||
|         "@types/bootstrap": "~5.1.6", | ||||
| @@ -123,10 +124,10 @@ | ||||
|         "eslint-plugin-vue": "~7.18.0", | ||||
|         "jest": "~27.2.5", | ||||
|         "jest-puppeteer": "~6.0.0", | ||||
|         "puppeteer": "~10.4.0", | ||||
|         "puppeteer": "~13.1.3", | ||||
|         "sass": "~1.42.1", | ||||
|         "stylelint": "~13.13.1", | ||||
|         "stylelint-config-standard": "~22.0.0", | ||||
|         "stylelint": "~14.2.0", | ||||
|         "stylelint-config-standard": "~24.0.0", | ||||
|         "typescript": "~4.4.4", | ||||
|         "vite": "~2.6.14" | ||||
|     } | ||||
|   | ||||
| @@ -119,6 +119,19 @@ class Monitor extends BeanModel { | ||||
|  | ||||
|         const beat = async () => { | ||||
|  | ||||
|             let beatInterval = this.interval; | ||||
|  | ||||
|             if (! beatInterval) { | ||||
|                 beatInterval = 1; | ||||
|             } | ||||
|  | ||||
|             if (demoMode) { | ||||
|                 if (beatInterval < 20) { | ||||
|                     console.log("beat interval too low, reset to 20s"); | ||||
|                     beatInterval = 20; | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             // Expose here for prometheus update | ||||
|             // undefined if not https | ||||
|             let tlsInfo = undefined; | ||||
| @@ -168,7 +181,7 @@ class Monitor extends BeanModel { | ||||
|                         ...(this.body ? { data: JSON.parse(this.body) } : {}), | ||||
|                         timeout: this.interval * 1000 * 0.8, | ||||
|                         headers: { | ||||
|                             "Accept": "*/*", | ||||
|                             "Accept": "text/html,application/xhtml+xml,application/xml;q=0.9,image/avif,image/webp,image/apng,*/*;q=0.8,application/signed-exchange;v=b3;q=0.9", | ||||
|                             "User-Agent": "Uptime-Kuma/" + version, | ||||
|                             ...(this.headers ? JSON.parse(this.headers) : {}), | ||||
|                             ...(basicAuthHeader), | ||||
| @@ -303,7 +316,7 @@ class Monitor extends BeanModel { | ||||
|                     } else { | ||||
|                         // No need to insert successful heartbeat for push type, so end here | ||||
|                         retries = 0; | ||||
|                         this.heartbeatInterval = setTimeout(beat, this.interval * 1000); | ||||
|                         this.heartbeatInterval = setTimeout(beat, beatInterval * 1000); | ||||
|                         return; | ||||
|                     } | ||||
|  | ||||
| @@ -377,8 +390,6 @@ class Monitor extends BeanModel { | ||||
|                 } | ||||
|             } | ||||
|  | ||||
|             let beatInterval = this.interval; | ||||
|  | ||||
|             debug(`[${this.name}] Check isImportant`); | ||||
|             let isImportant = Monitor.isImportantBeat(isFirstBeat, previousBeat?.status, bean.status); | ||||
|  | ||||
| @@ -422,14 +433,6 @@ class Monitor extends BeanModel { | ||||
|             previousBeat = bean; | ||||
|  | ||||
|             if (! this.isStop) { | ||||
|  | ||||
|                 if (demoMode) { | ||||
|                     if (beatInterval < 20) { | ||||
|                         console.log("beat interval too low, reset to 20s"); | ||||
|                         beatInterval = 20; | ||||
|                     } | ||||
|                 } | ||||
|  | ||||
|                 debug(`[${this.name}] SetTimeout for next check.`); | ||||
|                 this.heartbeatInterval = setTimeout(safeBeat, beatInterval * 1000); | ||||
|             } else { | ||||
|   | ||||
							
								
								
									
										47
									
								
								server/notification-providers/google-chat.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								server/notification-providers/google-chat.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,47 @@ | ||||
| const NotificationProvider = require("./notification-provider"); | ||||
| const axios = require("axios"); | ||||
| const { setting } = require("../util-server"); | ||||
| const { getMonitorRelativeURL } = require("../../src/util"); | ||||
| const { DOWN, UP } = require("../../src/util"); | ||||
|  | ||||
| class GoogleChat extends NotificationProvider { | ||||
|  | ||||
|     name = "GoogleChat"; | ||||
|  | ||||
|     async send(notification, msg, monitorJSON = null, heartbeatJSON = null) { | ||||
|         let okMsg = "Sent Successfully."; | ||||
|         try { | ||||
|             // Google Chat message formatting: https://developers.google.com/chat/api/guides/message-formats/basic | ||||
|  | ||||
|             let textMsg = '' | ||||
|             if (heartbeatJSON && heartbeatJSON.status === UP) { | ||||
|                 textMsg = `✅ Application is back online\n`; | ||||
|             } else if (heartbeatJSON && heartbeatJSON.status === DOWN) { | ||||
|                 textMsg = `🔴 Application went down\n`; | ||||
|             } | ||||
|  | ||||
|             if (monitorJSON && monitorJSON.name) { | ||||
|                 textMsg += `*${monitorJSON.name}*\n`; | ||||
|             } | ||||
|  | ||||
|             textMsg += `${msg}`; | ||||
|  | ||||
|             const baseURL = await setting("primaryBaseURL"); | ||||
|             if (baseURL && monitorJSON) { | ||||
|                 textMsg += `\n${baseURL + getMonitorRelativeURL(monitorJSON.id)}`; | ||||
|             } | ||||
|  | ||||
|             const data = { | ||||
|                 "text": textMsg, | ||||
|             }; | ||||
|  | ||||
|             await axios.post(notification.googleChatWebhookURL, data); | ||||
|             return okMsg; | ||||
|         } catch (error) { | ||||
|             this.throwGeneralAxiosError(error); | ||||
|         } | ||||
|  | ||||
|     } | ||||
| } | ||||
|  | ||||
| module.exports = GoogleChat; | ||||
| @@ -20,7 +20,7 @@ class Mattermost extends NotificationProvider { | ||||
|                 return okMsg; | ||||
|             } | ||||
|  | ||||
|             const mattermostChannel = notification.mattermostchannel; | ||||
|             const mattermostChannel = notification.mattermostchannel.toLowerCase(); | ||||
|             const mattermostIconEmoji = notification.mattermosticonemo; | ||||
|             const mattermostIconUrl = notification.mattermosticonurl; | ||||
|  | ||||
|   | ||||
| @@ -14,9 +14,21 @@ class SMTP extends NotificationProvider { | ||||
|             secure: notification.smtpSecure, | ||||
|             tls: { | ||||
|                 rejectUnauthorized: notification.smtpIgnoreTLSError || false, | ||||
|             }, | ||||
|             } | ||||
|         }; | ||||
|  | ||||
|         // Fix #1129 | ||||
|         if (notification.smtpDkimDomain) { | ||||
|             config.dkim = { | ||||
|                 domainName: notification.smtpDkimDomain, | ||||
|                 keySelector: notification.smtpDkimKeySelector, | ||||
|                 privateKey: notification.smtpDkimPrivateKey, | ||||
|                 hashAlgo: notification.smtpDkimHashAlgo, | ||||
|                 headerFieldNames: notification.smtpDkimheaderFieldNames, | ||||
|                 skipFields: notification.smtpDkimskipFields, | ||||
|             }; | ||||
|         } | ||||
|  | ||||
|         // Should fix the issue in https://github.com/louislam/uptime-kuma/issues/26#issuecomment-896373904 | ||||
|         if (notification.smtpUsername || notification.smtpPassword) { | ||||
|             config.auth = { | ||||
|   | ||||
							
								
								
									
										47
									
								
								server/notification-providers/wecom.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								server/notification-providers/wecom.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,47 @@ | ||||
| const NotificationProvider = require("./notification-provider"); | ||||
| const axios = require("axios"); | ||||
| const { DOWN, UP } = require("../../src/util"); | ||||
|  | ||||
| class WeCom extends NotificationProvider { | ||||
|  | ||||
|     name = "WeCom"; | ||||
|  | ||||
|     async send(notification, msg, monitorJSON = null, heartbeatJSON = null) { | ||||
|         let okMsg = "Sent Successfully."; | ||||
|  | ||||
|         try { | ||||
|             let WeComUrl = "https://qyapi.weixin.qq.com/cgi-bin/webhook/send?key=" + notification.weComBotKey; | ||||
|             let config = { | ||||
|                 headers: { | ||||
|                     "Content-Type": "application/json" | ||||
|                 } | ||||
|             }; | ||||
|             let body = this.composeMessage(heartbeatJSON, msg); | ||||
|             await axios.post(WeComUrl, body, config); | ||||
|             return okMsg; | ||||
|         } catch (error) { | ||||
|             this.throwGeneralAxiosError(error); | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     composeMessage(heartbeatJSON, msg) { | ||||
|         let title; | ||||
|         if (msg != null && heartbeatJSON != null && heartbeatJSON['status'] == UP) { | ||||
|             title = "UptimeKuma Monitor Up"; | ||||
|         } | ||||
|         if (msg != null && heartbeatJSON != null && heartbeatJSON["status"] == DOWN) { | ||||
|             title = "UptimeKuma Monitor Down"; | ||||
|         } | ||||
|         if (msg != null) { | ||||
|             title = "UptimeKuma Message"; | ||||
|         } | ||||
|         return { | ||||
|             msgtype: "text", | ||||
|             text: { | ||||
|                 content: title + msg | ||||
|             } | ||||
|         }; | ||||
|     } | ||||
| } | ||||
|  | ||||
| module.exports = WeCom; | ||||
| @@ -25,6 +25,8 @@ const DingDing = require("./notification-providers/dingding"); | ||||
| const Bark = require("./notification-providers/bark"); | ||||
| const SerwerSMS = require("./notification-providers/serwersms"); | ||||
| const Stackfield = require("./notification-providers/stackfield"); | ||||
| const WeCom = require("./notification-providers/wecom"); | ||||
| const GoogleChat = require("./notification-providers/google-chat"); | ||||
|  | ||||
| class Notification { | ||||
|  | ||||
| @@ -62,6 +64,8 @@ class Notification { | ||||
|             new Bark(), | ||||
|             new SerwerSMS(), | ||||
|             new Stackfield(), | ||||
|             new WeCom(), | ||||
|             new GoogleChat() | ||||
|         ]; | ||||
|  | ||||
|         for (let item of list) { | ||||
|   | ||||
| @@ -48,7 +48,7 @@ function Ping(host, options) { | ||||
|         this._args = (options.args) ? options.args : [ "-n", "-t", timeout, "-c", "1", host ]; | ||||
|         this._regmatch = /=([0-9.]+?) ms/; | ||||
|  | ||||
|     } else if (util.FBSD) { | ||||
|     } else if (util.BSD) { | ||||
|         this._bin = "/sbin/ping"; | ||||
|  | ||||
|         const defaultArgs = [ "-n", "-t", timeout, "-c", "1", host ]; | ||||
|   | ||||
| @@ -60,7 +60,9 @@ class Prometheus { | ||||
|             } | ||||
|  | ||||
|             try { | ||||
|                 monitor_cert_days_remaining.set(this.monitorLabelValues, tlsInfo.certInfo.daysRemaining); | ||||
|                 if (tlsInfo.certInfo != null) { | ||||
|                     monitor_cert_days_remaining.set(this.monitorLabelValues, tlsInfo.certInfo.daysRemaining); | ||||
|                 } | ||||
|             } catch (e) { | ||||
|                 console.error(e); | ||||
|             } | ||||
|   | ||||
| @@ -1,4 +1,15 @@ | ||||
| console.log("Welcome to Uptime Kuma"); | ||||
|  | ||||
| // Check Node.js Version | ||||
| const nodeVersion = parseInt(process.versions.node.split(".")[0]); | ||||
| const requiredVersion = 14; | ||||
| console.log(`Your Node.js version: ${nodeVersion}`); | ||||
|  | ||||
| if (nodeVersion < requiredVersion) { | ||||
|     console.error(`Error: Your Node.js version is not supported, please upgrade to Node.js >= ${requiredVersion}.`); | ||||
|     process.exit(-1); | ||||
| } | ||||
|  | ||||
| const args = require("args-parser")(process.argv); | ||||
| const { sleep, debug, getRandomInt, genSecret } = require("../src/util"); | ||||
| const config = require("./config"); | ||||
|   | ||||
| @@ -16,6 +16,7 @@ exports.WIN = /^win/.test(process.platform); | ||||
| exports.LIN = /^linux/.test(process.platform); | ||||
| exports.MAC = /^darwin/.test(process.platform); | ||||
| exports.FBSD = /^freebsd/.test(process.platform); | ||||
| exports.BSD = /bsd$/.test(process.platform); | ||||
|  | ||||
| /** | ||||
|  * Init or reset JWT secret | ||||
|   | ||||
| @@ -313,6 +313,20 @@ textarea.form-control { | ||||
|     opacity: 0; | ||||
| } | ||||
|  | ||||
| .slide-fade-up-enter-active { | ||||
|     transition: all 0.2s $easing-in; | ||||
| } | ||||
|  | ||||
| .slide-fade-up-leave-active { | ||||
|     transition: all 0.2s $easing-in; | ||||
| } | ||||
|  | ||||
| .slide-fade-up-enter-from, | ||||
| .slide-fade-up-leave-to { | ||||
|     transform: translateY(-50px); | ||||
|     opacity: 0; | ||||
| } | ||||
|  | ||||
| .monitor-list { | ||||
|     &.scrollbar { | ||||
|         min-height: calc(100vh - 240px); | ||||
|   | ||||
| @@ -16,8 +16,8 @@ | ||||
|  | ||||
|                 <div v-if="tokenRequired"> | ||||
|                     <div class="form-floating mt-3"> | ||||
|                         <input id="floatingToken" v-model="token" type="text" maxlength="6" class="form-control" placeholder="123456"> | ||||
|                         <label for="floatingToken">{{ $t("Token") }}</label> | ||||
|                         <input id="otp" v-model="token" type="text" maxlength="6" class="form-control" placeholder="123456"> | ||||
|                         <label for="otp">{{ $t("Token") }}</label> | ||||
|                     </div> | ||||
|                 </div> | ||||
|  | ||||
|   | ||||
							
								
								
									
										67
									
								
								src/components/ToggleSection.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										67
									
								
								src/components/ToggleSection.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,67 @@ | ||||
| <template> | ||||
|     <div class="my-3 py-3"> | ||||
|         <h5 @click="isOpen = !isOpen"> | ||||
|             <div | ||||
|                 class=" | ||||
|                     w-50 | ||||
|                     d-flex | ||||
|                     justify-content-between | ||||
|                     align-items-center | ||||
|                     pe-2 | ||||
|                 " | ||||
|             > | ||||
|                 <span class="pb-2">{{ heading }}</span> | ||||
|                 <font-awesome-icon | ||||
|                     icon="chevron-down" | ||||
|                     class="animated" | ||||
|                     :class="{ open: isOpen }" | ||||
|                 /> | ||||
|             </div> | ||||
|         </h5> | ||||
|         <transition name="slide-fade-up"> | ||||
|             <div v-if="isOpen" class="mt-3"> | ||||
|                 <slot></slot> | ||||
|             </div> | ||||
|         </transition> | ||||
|     </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| export default { | ||||
|     props: { | ||||
|         heading: { | ||||
|             type: String, | ||||
|             default: "", | ||||
|         }, | ||||
|         defaultOpen: { | ||||
|             type: Boolean, | ||||
|             default: false, | ||||
|         }, | ||||
|     }, | ||||
|     data() { | ||||
|         return { | ||||
|             isOpen: this.defaultOpen, | ||||
|         }; | ||||
|     }, | ||||
| }; | ||||
| </script> | ||||
|  | ||||
| <style lang="scss" scoped> | ||||
| @import "../assets/vars.scss"; | ||||
|  | ||||
| h5:after { | ||||
|     content: ""; | ||||
|     display: block; | ||||
|     width: 50%; | ||||
|     padding-top: 8px; | ||||
|     border-bottom: 1px solid $dark-border-color; | ||||
| } | ||||
|  | ||||
| .open { | ||||
|     transform: rotate(180deg); | ||||
| } | ||||
|  | ||||
| .animated { | ||||
|     transition: all 0.2s $easing-in; | ||||
| } | ||||
| </style> | ||||
| @@ -6,7 +6,7 @@ | ||||
|         <label for="secretAccessKey" class="form-label">{{ $t("SecretAccessKey") }}<span style="color: red;"><sup>*</sup></span></label> | ||||
|         <input id="secretAccessKey" v-model="$parent.notification.secretAccessKey" type="text" class="form-control" required> | ||||
|  | ||||
|         <label for="phonenumber" class="form-label">{{ $t("Phonenumber") }}<span style="color: red;"><sup>*</sup></span></label> | ||||
|         <label for="phonenumber" class="form-label">{{ $t("PhoneNumbers") }}<span style="color: red;"><sup>*</sup></span></label> | ||||
|         <input id="phonenumber" v-model="$parent.notification.phonenumber" type="text" class="form-control" required> | ||||
|  | ||||
|         <label for="templateCode" class="form-label">{{ $t("TemplateCode") }}<span style="color: red;"><sup>*</sup></span></label> | ||||
| @@ -16,7 +16,7 @@ | ||||
|         <input id="signName" v-model="$parent.notification.signName" type="text" class="form-control" required> | ||||
|  | ||||
|         <div class="form-text"> | ||||
|             <p>Sms template must contain parameters: <br> <code>${name} ${time} ${status} ${msg}</code></p> | ||||
|             <p>{{ $t("Sms template must contain parameters: ") }}<br> <code>${name} ${time} ${status} ${msg}</code></p> | ||||
|             <i18n-t tag="p" keypath="Read more:"> | ||||
|                 <a href="https://help.aliyun.com/document_detail/101414.html" target="_blank">https://help.aliyun.com/document_detail/101414.html</a> | ||||
|             </i18n-t> | ||||
|   | ||||
| @@ -7,9 +7,9 @@ | ||||
|         <input id="secretKey" v-model="$parent.notification.secretKey" type="text" class="form-control" required> | ||||
|  | ||||
|         <div class="form-text"> | ||||
|             <p>For safety, must use secret key</p> | ||||
|             <p>{{ $t("For safety, must use secret key") }}</p> | ||||
|             <i18n-t tag="p" keypath="Read more:"> | ||||
|                 <a href="https://developers.dingtalk.com/document/robots/custom-robot-access" target="_blank">https://developers.dingtalk.com/document/robots/custom-robot-access</a> | ||||
|                 <a href="https://developers.dingtalk.com/document/robots/custom-robot-access" target="_blank">https://developers.dingtalk.com/document/robots/custom-robot-access</a> <a href="https://open.dingtalk.com/document/robots/customize-robot-security-settings#title-7fs-kgs-36x" target="_blank">https://open.dingtalk.com/document/robots/customize-robot-security-settings#title-7fs-kgs-36x</a> | ||||
|             </i18n-t> | ||||
|         </div> | ||||
|     </div> | ||||
|   | ||||
							
								
								
									
										13
									
								
								src/components/notifications/GoogleChat.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										13
									
								
								src/components/notifications/GoogleChat.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,13 @@ | ||||
| <template> | ||||
|     <div class="mb-3"> | ||||
|         <label for="google-chat-webhook-url" class="form-label">{{ $t("Webhook URL") }}<span style="color: red;"><sup>*</sup></span></label> | ||||
|         <input id="google-chat-webhook-url" v-model="$parent.notification.googleChatWebhookURL" type="text" class="form-control" required> | ||||
|  | ||||
|         <div class="form-text"> | ||||
|             <span style="color: red;"><sup>*</sup></span>{{ $t("Required") }} | ||||
|             <i18n-t tag="p" keypath="aboutWebhooks" style="margin-top: 8px;"> | ||||
|                 <a href="https://developers.google.com/chat/how-tos/webhooks" target="_blank">https://developers.google.com/chat/how-tos/webhooks</a> | ||||
|             </i18n-t> | ||||
|         </div> | ||||
|     </div> | ||||
| </template> | ||||
| @@ -1,82 +1,117 @@ | ||||
| <template> | ||||
|     <div class="mb-3"> | ||||
|         <label for="hostname" class="form-label">{{ $t("Hostname") }}</label> | ||||
|         <input id="hostname" v-model="$parent.notification.smtpHost" type="text" class="form-control" required> | ||||
|     </div> | ||||
|  | ||||
|     <div class="mb-3"> | ||||
|         <label for="port" class="form-label">{{ $t("Port") }}</label> | ||||
|         <input id="port" v-model="$parent.notification.smtpPort" type="number" class="form-control" required min="0" max="65535" step="1"> | ||||
|     </div> | ||||
|  | ||||
|     <div class="mb-3"> | ||||
|         <label for="secure" class="form-label">{{ $t("Security") }}</label> | ||||
|         <select id="secure" v-model="$parent.notification.smtpSecure" class="form-select"> | ||||
|             <option :value="false">{{ $t("secureOptionNone") }}</option> | ||||
|             <option :value="true">{{ $t("secureOptionTLS") }}</option> | ||||
|         </select> | ||||
|     </div> | ||||
|  | ||||
|     <div class="mb-3"> | ||||
|         <div class="form-check"> | ||||
|             <input id="ignore-tls-error" v-model="$parent.notification.smtpIgnoreTLSError" class="form-check-input" type="checkbox" value=""> | ||||
|             <label class="form-check-label" for="ignore-tls-error"> | ||||
|                 {{ $t("Ignore TLS Error") }} | ||||
|             </label> | ||||
|     <div> | ||||
|         <div class="mb-3"> | ||||
|             <label for="hostname" class="form-label">{{ $t("Hostname") }}</label> | ||||
|             <input id="hostname" v-model="$parent.notification.smtpHost" type="text" class="form-control" required> | ||||
|         </div> | ||||
|     </div> | ||||
|  | ||||
|     <div class="mb-3"> | ||||
|         <label for="username" class="form-label">{{ $t("Username") }}</label> | ||||
|         <input id="username" v-model="$parent.notification.smtpUsername" type="text" class="form-control" autocomplete="false"> | ||||
|     </div> | ||||
|  | ||||
|     <div class="mb-3"> | ||||
|         <label for="password" class="form-label">{{ $t("Password") }}</label> | ||||
|         <HiddenInput id="password" v-model="$parent.notification.smtpPassword" :required="false" autocomplete="one-time-code"></HiddenInput> | ||||
|     </div> | ||||
|  | ||||
|     <div class="mb-3"> | ||||
|         <label for="from-email" class="form-label">{{ $t("From Email") }}</label> | ||||
|         <input id="from-email" v-model="$parent.notification.smtpFrom" type="text" class="form-control" required autocomplete="false" placeholder=""Uptime Kuma" <example@kuma.pet>"> | ||||
|         <div class="form-text"> | ||||
|         <div class="mb-3"> | ||||
|             <label for="port" class="form-label">{{ $t("Port") }}</label> | ||||
|             <input id="port" v-model="$parent.notification.smtpPort" type="number" class="form-control" required min="0" max="65535" step="1"> | ||||
|         </div> | ||||
|     </div> | ||||
|  | ||||
|     <div class="mb-3"> | ||||
|         <label for="to-email" class="form-label">{{ $t("To Email") }}</label> | ||||
|         <input id="to-email" v-model="$parent.notification.smtpTo" type="text" class="form-control" autocomplete="false" placeholder="example2@kuma.pet, example3@kuma.pet" :required="!hasRecipient"> | ||||
|     </div> | ||||
|         <div class="mb-3"> | ||||
|             <label for="secure" class="form-label">{{ $t("Security") }}</label> | ||||
|             <select id="secure" v-model="$parent.notification.smtpSecure" class="form-select"> | ||||
|                 <option :value="false">{{ $t("secureOptionNone") }}</option> | ||||
|                 <option :value="true">{{ $t("secureOptionTLS") }}</option> | ||||
|             </select> | ||||
|         </div> | ||||
|  | ||||
|     <div class="mb-3"> | ||||
|         <label for="to-cc" class="form-label">{{ $t("smtpCC") }}</label> | ||||
|         <input id="to-cc" v-model="$parent.notification.smtpCC" type="text" class="form-control" autocomplete="false" :required="!hasRecipient"> | ||||
|     </div> | ||||
|         <div class="mb-3"> | ||||
|             <div class="form-check"> | ||||
|                 <input id="ignore-tls-error" v-model="$parent.notification.smtpIgnoreTLSError" class="form-check-input" type="checkbox" value=""> | ||||
|                 <label class="form-check-label" for="ignore-tls-error"> | ||||
|                     {{ $t("Ignore TLS Error") }} | ||||
|                 </label> | ||||
|             </div> | ||||
|         </div> | ||||
|  | ||||
|     <div class="mb-3"> | ||||
|         <label for="to-bcc" class="form-label">{{ $t("smtpBCC") }}</label> | ||||
|         <input id="to-bcc" v-model="$parent.notification.smtpBCC" type="text" class="form-control" autocomplete="false" :required="!hasRecipient"> | ||||
|     </div> | ||||
|         <div class="mb-3"> | ||||
|             <label for="username" class="form-label">{{ $t("Username") }}</label> | ||||
|             <input id="username" v-model="$parent.notification.smtpUsername" type="text" class="form-control" autocomplete="false"> | ||||
|         </div> | ||||
|  | ||||
|     <div class="mb-3"> | ||||
|         <label for="subject-email" class="form-label">{{ $t("emailCustomSubject") }}</label> | ||||
|         <input id="subject-email" v-model="$parent.notification.customSubject" type="text" class="form-control" autocomplete="false" placeholder=""> | ||||
|         <div v-pre class="form-text"> | ||||
|             (leave blank for default one)<br /> | ||||
|             {{NAME}}: Service Name<br /> | ||||
|             {{HOSTNAME_OR_URL}}: Hostname or URL<br /> | ||||
|             {{URL}}: URL<br /> | ||||
|             {{STATUS}}: Status<br /> | ||||
|         <div class="mb-3"> | ||||
|             <label for="password" class="form-label">{{ $t("Password") }}</label> | ||||
|             <HiddenInput id="password" v-model="$parent.notification.smtpPassword" :required="false" autocomplete="one-time-code"></HiddenInput> | ||||
|         </div> | ||||
|  | ||||
|         <div class="mb-3"> | ||||
|             <label for="from-email" class="form-label">{{ $t("From Email") }}</label> | ||||
|             <input id="from-email" v-model="$parent.notification.smtpFrom" type="text" class="form-control" required autocomplete="false" placeholder=""Uptime Kuma" <example@kuma.pet>"> | ||||
|             <div class="form-text"> | ||||
|             </div> | ||||
|         </div> | ||||
|  | ||||
|         <div class="mb-3"> | ||||
|             <label for="to-email" class="form-label">{{ $t("To Email") }}</label> | ||||
|             <input id="to-email" v-model="$parent.notification.smtpTo" type="text" class="form-control" autocomplete="false" placeholder="example2@kuma.pet, example3@kuma.pet" :required="!hasRecipient"> | ||||
|         </div> | ||||
|  | ||||
|         <div class="mb-3"> | ||||
|             <label for="to-cc" class="form-label">{{ $t("smtpCC") }}</label> | ||||
|             <input id="to-cc" v-model="$parent.notification.smtpCC" type="text" class="form-control" autocomplete="false" :required="!hasRecipient"> | ||||
|         </div> | ||||
|  | ||||
|         <div class="mb-3"> | ||||
|             <label for="to-bcc" class="form-label">{{ $t("smtpBCC") }}</label> | ||||
|             <input id="to-bcc" v-model="$parent.notification.smtpBCC" type="text" class="form-control" autocomplete="false" :required="!hasRecipient"> | ||||
|         </div> | ||||
|  | ||||
|         <ToggleSection :heading="$t('smtpDkimSettings')"> | ||||
|             <i18n-t tag="div" keypath="smtpDkimDesc" class="form-text mb-3"> | ||||
|                 <a href="https://nodemailer.com/dkim/" target="_blank">{{ $t("documentation") }}</a> | ||||
|             </i18n-t> | ||||
|  | ||||
|             <div class="mb-3"> | ||||
|                 <label for="dkim-domain" class="form-label">{{ $t("smtpDkimDomain") }}</label> | ||||
|                 <input id="dkim-domain" v-model="$parent.notification.smtpDkimDomain" type="text" class="form-control" autocomplete="false" placeholder="example.com"> | ||||
|             </div> | ||||
|             <div class="mb-3"> | ||||
|                 <label for="dkim-key-selector" class="form-label">{{ $t("smtpDkimKeySelector") }}</label> | ||||
|                 <input id="dkim-key-selector" v-model="$parent.notification.smtpDkimKeySelector" type="text" class="form-control" autocomplete="false" placeholder="2017"> | ||||
|             </div> | ||||
|             <div class="mb-3"> | ||||
|                 <label for="dkim-private-key" class="form-label">{{ $t("smtpDkimPrivateKey") }}</label> | ||||
|                 <textarea id="dkim-private-key" v-model="$parent.notification.smtpDkimPrivateKey" rows="5" type="text" class="form-control" autocomplete="false" placeholder="-----BEGIN PRIVATE KEY-----"></textarea> | ||||
|             </div> | ||||
|             <div class="mb-3"> | ||||
|                 <label for="dkim-hash-algo" class="form-label">{{ $t("smtpDkimHashAlgo") }}</label> | ||||
|                 <input id="dkim-hash-algo" v-model="$parent.notification.smtpDkimHashAlgo" type="text" class="form-control" autocomplete="false" placeholder="sha256"> | ||||
|             </div> | ||||
|             <div class="mb-3"> | ||||
|                 <label for="dkim-header-fields" class="form-label">{{ $t("smtpDkimheaderFieldNames") }}</label> | ||||
|                 <input id="dkim-header-fields" v-model="$parent.notification.smtpDkimheaderFieldNames" type="text" class="form-control" autocomplete="false" placeholder="message-id:date:from:to"> | ||||
|             </div> | ||||
|             <div class="mb-3"> | ||||
|                 <label for="dkim-skip-fields" class="form-label">{{ $t("smtpDkimskipFields") }}</label> | ||||
|                 <input id="dkim-skip-fields" v-model="$parent.notification.smtpDkimskipFields" type="text" class="form-control" autocomplete="false" placeholder="message-id:date"> | ||||
|             </div> | ||||
|         </ToggleSection> | ||||
|  | ||||
|         <div class="mb-3"> | ||||
|             <label for="subject-email" class="form-label">{{ $t("emailCustomSubject") }}</label> | ||||
|             <input id="subject-email" v-model="$parent.notification.customSubject" type="text" class="form-control" autocomplete="false" placeholder=""> | ||||
|             <div v-pre class="form-text"> | ||||
|                 (leave blank for default one)<br /> | ||||
|                 {{NAME}}: Service Name<br /> | ||||
|                 {{HOSTNAME_OR_URL}}: Hostname or URL<br /> | ||||
|                 {{URL}}: URL<br /> | ||||
|                 {{STATUS}}: Status<br /> | ||||
|             </div> | ||||
|         </div> | ||||
|     </div> | ||||
| </template> | ||||
|  | ||||
| <script> | ||||
| import HiddenInput from "../HiddenInput.vue"; | ||||
| import ToggleSection from "../ToggleSection.vue"; | ||||
|  | ||||
| export default { | ||||
|     components: { | ||||
|         HiddenInput, | ||||
|         ToggleSection, | ||||
|     }, | ||||
|     computed: { | ||||
|         hasRecipient() { | ||||
|   | ||||
| @@ -63,9 +63,9 @@ export default { | ||||
|                     let update = res.data.result[res.data.result.length - 1]; | ||||
|  | ||||
|                     if (update.channel_post) { | ||||
|                         this.notification.telegramChatID = update.channel_post.chat.id; | ||||
|                         this.$parent.notification.telegramChatID = update.channel_post.chat.id; | ||||
|                     } else if (update.message) { | ||||
|                         this.notification.telegramChatID = update.message.chat.id; | ||||
|                         this.$parent.notification.telegramChatID = update.message.chat.id; | ||||
|                     } else { | ||||
|                         throw new Error(this.$t("chatIDNotFound")); | ||||
|                     } | ||||
|   | ||||
							
								
								
									
										12
									
								
								src/components/notifications/WeCom.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								src/components/notifications/WeCom.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,12 @@ | ||||
| <template> | ||||
|     <div class="mb-3"> | ||||
|         <label for="WeCom Bot Key" class="form-label">{{ $t("WeCom Bot Key") }}<span style="color: red;"><sup>*</sup></span></label> | ||||
|         <input id="WeCom Bot Key" v-model="$parent.notification.weComBotKey" type="text" class="form-control" required> | ||||
|         <div class="form-text"> | ||||
|             <p><span style="color: red;"><sup>*</sup></span>{{ $t("Required") }}</p> | ||||
|         </div> | ||||
|         <i18n-t tag="p" keypath="Read more:"> | ||||
|             <a href="https://work.weixin.qq.com/api/doc/90000/90136/91770" target="_blank">https://work.weixin.qq.com/api/doc/90000/90136/91770</a> | ||||
|         </i18n-t> | ||||
|     </div> | ||||
| </template> | ||||
| @@ -1,4 +1,4 @@ | ||||
| import STMP from "./SMTP.vue" | ||||
| import STMP from "./SMTP.vue"; | ||||
| import Telegram from "./Telegram.vue"; | ||||
| import Discord from "./Discord.vue"; | ||||
| import Webhook from "./Webhook.vue"; | ||||
| @@ -24,6 +24,8 @@ import DingDing from "./DingDing.vue"; | ||||
| import Bark from "./Bark.vue"; | ||||
| import SerwerSMS from "./SerwerSMS.vue"; | ||||
| import Stackfield from './Stackfield.vue'; | ||||
| import WeCom from "./WeCom.vue"; | ||||
| import GoogleChat from "./GoogleChat.vue"; | ||||
|  | ||||
| /** | ||||
|  * Manage all notification form. | ||||
| @@ -57,6 +59,8 @@ const NotificationFormList = { | ||||
|     "Bark": Bark, | ||||
|     "serwersms": SerwerSMS, | ||||
|     "stackfield": Stackfield, | ||||
| } | ||||
|     "WeCom": WeCom, | ||||
|     "GoogleChat": GoogleChat | ||||
| }; | ||||
|  | ||||
| export default NotificationFormList | ||||
| export default NotificationFormList; | ||||
|   | ||||
| @@ -126,6 +126,12 @@ | ||||
|                 <p>Bitte mit Vorsicht nutzen.</p> | ||||
|             </template> | ||||
|  | ||||
|             <template v-else-if="$i18n.locale === 'sl-SI' "> | ||||
|                 <p>Ali ste prepričani, da želite onemogočiti <strong>avtentikacijo</strong>?</p> | ||||
|                 <p>Namenjen je <strong>nekomu, ki ima pred programom Uptime Kuma vklopljeno zunanje preverjanje pristnosti</strong>, na primer Cloudflare Access.</p> | ||||
|                 <p>Uporabljajte previdno.</p> | ||||
|             </template> | ||||
|  | ||||
|             <template v-else-if="$i18n.locale === 'sr' "> | ||||
|                 <p>Да ли сте сигурни да желите да <strong>искључите аутентификацију</strong>?</p> | ||||
|                 <p>То је за <strong>оне који имају додату аутентификацију</strong> испред Uptime Kuma као на пример Cloudflare Access.</p> | ||||
| @@ -169,9 +175,9 @@ | ||||
|             </template> | ||||
|  | ||||
|             <template v-else-if="$i18n.locale === 'it-IT' "> | ||||
|                 <p>Si è certi di voler <strong>disabilitare l'autenticazione</strong>?</p> | ||||
|                 <p>È per <strong>chi ha l'autenticazione gestita da terze parti</strong> messa davanti ad Uptime Kuma, ad esempio Cloudflare Access.</p> | ||||
|                 <p>Utilizzare con attenzione.</p> | ||||
|                 <p><strong>Disabilitare l'autenticazione?</strong></p> | ||||
|                 <p><strong>Questa opzione è per chi un sistema di autenticazione gestito da terze parti</strong> messo davanti ad Uptime Kuma, ad esempio Cloudflare Access.</p> | ||||
|                 <p>Utilizzare con attenzione!</p> | ||||
|             </template> | ||||
|  | ||||
|             <template v-else-if="$i18n.locale === 'id-ID' "> | ||||
| @@ -210,11 +216,23 @@ | ||||
|                 <p>Vennligst vær forsiktig.</p> | ||||
|             </template> | ||||
|              | ||||
|             <template v-else-if="$i18n.locale === 'cs-CZ' "> | ||||
|                 <p>Opravdu chcete <strong>deaktivovat autentifikaci</strong>?</p> | ||||
|                 <p>Tato možnost je určena pro případy, kdy <strong>máte autentifikaci zajištěnou třetí stranou</strong> ještě před přístupem do Uptime Kuma, například prostřednictvím Cloudflare Access.</p> | ||||
|                 <p>Používejte ji prosím s rozmyslem.</p> | ||||
|             </template> | ||||
|  | ||||
| 			<template v-else-if="$i18n.locale === 'vi-VN' "> | ||||
|                 <p>Bạn có muốn <strong>TẮT XÁC THỰC</strong> không?</p> | ||||
|                 <p>Điều này rất nguy hiểm<strong>BẤT KỲ AI</strong> cũng có thể truy cập và cướp quyền điều khiển.</p> | ||||
|                 <p>Vui lòng <strong>cẩn thận</strong>.</p> | ||||
|             </template> | ||||
|  | ||||
|             <!-- English (en) --> | ||||
|             <template v-else> | ||||
|                 <p>Are you sure want to <strong>disable auth</strong>?</p> | ||||
|                 <p>It is for <strong>someone who have 3rd-party auth</strong> in front of Uptime Kuma such as Cloudflare Access.</p> | ||||
|                 <p>Please use it carefully.</p> | ||||
|                 <p>Are you sure want to <strong>disable authentication</strong>?</p> | ||||
|                 <p>It is designed for scenarios <strong>where you intend to implement third-party authentication</strong> in front of Uptime Kuma such as Cloudflare Access, Authelia or other authentication mechanisms.</p> | ||||
|                 <p>Please use this option carefully!</p> | ||||
|             </template> | ||||
|         </Confirm> | ||||
|     </div> | ||||
|   | ||||
| @@ -2,6 +2,7 @@ import { createI18n } from "vue-i18n/index"; | ||||
| import en from "./languages/en"; | ||||
|  | ||||
| const languageList = { | ||||
|     "cs-CZ": "Čeština", | ||||
|     "zh-HK": "繁體中文 (香港)", | ||||
|     "bg-BG": "Български", | ||||
|     "de-DE": "Deutsch (Deutschland)", | ||||
| @@ -18,6 +19,7 @@ const languageList = { | ||||
|     "ja": "日本語", | ||||
|     "da-DK": "Danish (Danmark)", | ||||
|     "sr": "Српски", | ||||
|     "sl-SI": "Slovenščina", | ||||
|     "sr-latn": "Srpski", | ||||
|     "sv-SE": "Svenska", | ||||
|     "tr-TR": "Türkçe", | ||||
| @@ -26,7 +28,7 @@ const languageList = { | ||||
|     "zh-CN": "简体中文", | ||||
|     "pl": "Polski", | ||||
|     "et-EE": "eesti", | ||||
|     "vi": "Vietnamese", | ||||
|     "vi-VN": "Tiếng Việt", | ||||
|     "zh-TW": "繁體中文 (台灣)" | ||||
| }; | ||||
|  | ||||
|   | ||||
| @@ -33,6 +33,7 @@ import { | ||||
|     faFile, | ||||
|     faAward, | ||||
|     faLink, | ||||
|     faChevronDown, | ||||
| } from "@fortawesome/free-solid-svg-icons"; | ||||
|  | ||||
| library.add( | ||||
| @@ -65,6 +66,7 @@ library.add( | ||||
|     faFile, | ||||
|     faAward, | ||||
|     faLink, | ||||
|     faChevronDown, | ||||
| ); | ||||
|  | ||||
| export { FontAwesomeIcon }; | ||||
|   | ||||
| @@ -13,7 +13,7 @@ export default { | ||||
|     pauseDashboardHome: "Пауза", | ||||
|     deleteMonitorMsg: "Наистина ли желаете да изтриете този монитор?", | ||||
|     deleteNotificationMsg: "Наистина ли желаете да изтриете това известяване за всички монитори?", | ||||
|     resoverserverDescription: "Cloudflare е сървърът по подразбиране, но можете да го промените по всяко време.", | ||||
|     resolverserverDescription: "Cloudflare е сървърът по подразбиране, но можете да го промените по всяко време.", | ||||
|     rrtypeDescription: "Изберете ресурсния запис, който желаете да наблюдавате", | ||||
|     pauseMonitorMsg: "Наистина ли желаете да поставите в режим пауза?", | ||||
|     enableDefaultNotificationDescription: "За всеки нов монитор това известяване ще бъде активирано по подразбиране. Можете да го изключите за всеки отделен монитор.", | ||||
| @@ -131,8 +131,8 @@ export default { | ||||
|     Events: "Събития", | ||||
|     Heartbeats: "Проверки", | ||||
|     "Auto Get": "Авт. попълване", | ||||
|     backupDescription: "Можете да архивирате всички монитори и всички известия в JSON файл.", | ||||
|     backupDescription2: "PS: Данни за история и събития не са включени.", | ||||
|     backupDescription: "Можете да архивирате всички монитори и всички известявания в JSON файл.", | ||||
|     backupDescription2: "PS: Имайте предвид, че данните за история и събития няма да бъдат включени.", | ||||
|     backupDescription3: "Чувствителни данни, като токен кодове за известяване, се съдържат в експортирания файл. Моля, бъдете внимателни с неговото съхранение.", | ||||
|     alertNoFile: "Моля, изберете файл за импортиране.", | ||||
|     alertWrongFileType: "Моля, изберете JSON файл.", | ||||
| @@ -200,7 +200,7 @@ export default { | ||||
|     "Primary Base URL": "Основен базов URL адрес", | ||||
|     "Push URL": "Генериран Push URL адрес", | ||||
|     needPushEvery: "Необходимо е да извършвате заявка към този URL адрес на всеки {0} секунди", | ||||
|     pushOptionalParams: "Допълнителни, но незадължителни параметри: {0}", | ||||
|     pushOptionalParams: "Допълнителни, но не задължителни параметри: {0}", | ||||
|     defaultNotificationName: "Моето {notification} известяване ({number})", | ||||
|     here: "тук", | ||||
|     Required: "Задължително поле", | ||||
| @@ -308,4 +308,56 @@ export default { | ||||
|     "Current User": "Текущ потребител", | ||||
|     recent: "Скорошни", | ||||
|     shrinkDatabaseDescription: "Инициира \"VACUUM\" за \"SQLite\" база данни. Ако Вашата база данни е създадена след версия 1.10.0, \"AUTO_VACUUM\" функцията е активна и това действие не нужно.", | ||||
|     Done: "Готово", | ||||
|     Info: "Информация", | ||||
|     Security: "Сигурност", | ||||
|     "Steam API Key": "Steam API ключ", | ||||
|     "Shrink Database": "Редуциране база данни", | ||||
|     "Pick a RR-Type...": "Изберете вида на ресурсния запис за мониторитане...", | ||||
|     "Pick Accepted Status Codes...": "Изберете статус кодове, които да се считат за успешен отговор...", | ||||
|     Default: "По подразбиране", | ||||
|     "HTTP Options": "HTTP Опции", | ||||
|     "Create Incident": "Създаване на инцидент", | ||||
|     Title: "Заглавие", | ||||
|     Content: "Съдържание", | ||||
|     Style: "Стил", | ||||
|     info: "информация", | ||||
|     warning: "предупреждение", | ||||
|     danger: "опасност", | ||||
|     primary: "основен", | ||||
|     light: "светъл", | ||||
|     dark: "тъмен", | ||||
|     Post: "Публикувай", | ||||
|     "Please input title and content": "Моля, въведете заглавие и съдържание", | ||||
|     Created: "Създаден", | ||||
|     "Last Updated": "Последно обновен", | ||||
|     Unpin: "Откачи", | ||||
|     "Switch to Light Theme": "Превключи към светла тема", | ||||
|     "Switch to Dark Theme": "Превключи към тъмна тема", | ||||
|     "Show Tags": "Покажи етикети", | ||||
|     "Hide Tags": "Скрий етикети", | ||||
|     Description: "Описание", | ||||
|     "No monitors available.": "Няма налични монитори.", | ||||
|     "Add one": "Добави един", | ||||
|     "No Monitors": "Няма монитори", | ||||
|     "Untitled Group": "Група без заглавие", | ||||
|     Services: "Услуги", | ||||
|     Discard: "Премахни", | ||||
|     Cancel: "Отмени", | ||||
|     "Powered by": "Създадено чрез", | ||||
|     serwersms: "SerwerSMS.pl", | ||||
|     serwersmsAPIUser: "API Потребителско име (вкл. webapi_ prefix)", | ||||
|     serwersmsAPIPassword: "API Парола", | ||||
|     serwersmsPhoneNumber: "Телефон номер", | ||||
|     serwersmsSenderName: "SMS Подател име (регистриран през клиентския портал)", | ||||
|     stackfield: "Stackfield", | ||||
|     smtpDkimSettings: "DKIM Настройки", | ||||
|     smtpDkimDesc: "Моля, вижте Nodemailer DKIM {0} за инструкции.", | ||||
|     documentation: "документация", | ||||
|     smtpDkimDomain: "Домейн", | ||||
|     smtpDkimKeySelector: "Селектор на ключ", | ||||
|     smtpDkimPrivateKey: "Частен ключ", | ||||
|     smtpDkimHashAlgo: "Хеш алгоритъм (по желание)", | ||||
|     smtpDkimheaderFieldNames: "Хедър ключове за подписване (по желание)", | ||||
|     smtpDkimskipFields: "Хедър ключове, които да не се подписват (по желание)", | ||||
| }; | ||||
|   | ||||
							
								
								
									
										364
									
								
								src/languages/cs-CZ.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										364
									
								
								src/languages/cs-CZ.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,364 @@ | ||||
| export default { | ||||
|     languageName: "Czech", | ||||
|     checkEverySecond: "Kontrolovat každých {0} sekund", | ||||
|     retryCheckEverySecond: "Opakovat každých {0} sekund", | ||||
|     retriesDescription: "Maximální počet pokusů před označením služby jako nedostupné a odesláním oznámení", | ||||
|     ignoreTLSError: "Ignorovat TLS/SSL chyby na HTTPS stránkách", | ||||
|     upsideDownModeDescription: "Pomocí této možnosti změníte způsob vyhodnocování stavu. Pokud je služba dosažitelná, je NEDOSTUPNÁ.", | ||||
|     maxRedirectDescription: "Maximální počet přesměrování, která se mají následovat. Nastavením hodnoty 0 zakážete přesměrování.", | ||||
|     acceptedStatusCodesDescription: "Vyberte stavové kódy, které jsou považovány za úspěšnou odpověď.", | ||||
|     passwordNotMatchMsg: "Hesla se neshodují", | ||||
|     notificationDescription: "Pro zajištění funkčnosti oznámení je nutné je přiřadit dohledu.", | ||||
|     keywordDescription: "Vyhledat klíčové slovo v prosté odpovědi HTML nebo JSON. Při hledání se rozlišuje velikost písmen.", | ||||
|     pauseDashboardHome: "Pozastavit", | ||||
|     deleteMonitorMsg: "Opravdu chcete odstranit tento dohled?", | ||||
|     deleteNotificationMsg: "Opravdu chcete odstranit toto oznámení pro všechny dohledy?", | ||||
|     resolverserverDescription: "Cloudflare je výchozí server. Resolver server můžete kdykoli změnit.", | ||||
|     rrtypeDescription: "Vyberte typ záznamu o prostředku, který chcete monitorovat", | ||||
|     pauseMonitorMsg: "Opravdu chcete dohled pozastavit?", | ||||
|     enableDefaultNotificationDescription: "Toto oznámení bude standardně aktivní pro nové dohledy. V případě potřeby můžete oznámení stále zakázat na úrovni jednotlivých dohledů.", | ||||
|     clearEventsMsg: "Opravdu chcete odstranit všechny události pro tento dohled?", | ||||
|     clearHeartbeatsMsg: "Opravdu chcete odstranit všechny heartbeaty pro tento dohled?", | ||||
|     confirmClearStatisticsMsg: "Opravdu chcete smazat VŠECHNY statistiky?", | ||||
|     importHandleDescription: "Možnost 'Přeskočit existující' vyberte v případě, že chcete přeskočit všechny dohledy nebo oznámení se stejným názvem. Vybráním možnosti 'Přepsat' dojde k odstranění všech existujících dohledů a oznámení.", | ||||
|     confirmImportMsg: "Opravdu chcete importovat zálohu? Prosím ověřte, zda jste vybrali správnou možnost importu.", | ||||
|     twoFAVerifyLabel: "Prosím, zadejte svůj token pro ověření 2FA:", | ||||
|     tokenValidSettingsMsg: "Token je platný! Nyní můžete uložit nastavení 2FA.", | ||||
|     confirmEnableTwoFAMsg: "Opravdu chcete zapnout 2FA?", | ||||
|     confirmDisableTwoFAMsg: "Opravdu chcete deaktivovat 2FA?", | ||||
|     Settings: "Nastavení", | ||||
|     Dashboard: "Nástěnka", | ||||
|     "New Update": "Nová aktualizace", | ||||
|     Language: "Jazyk", | ||||
|     Appearance: "Vzhled", | ||||
|     Theme: "Motiv", | ||||
|     General: "Obecné", | ||||
|     "Primary Base URL": "Primární URL adresa", | ||||
|     Version: "Verze", | ||||
|     "Check Update On GitHub": "Zkontrolovat aktualizace na GitHubu", | ||||
|     List: "Seznam", | ||||
|     Add: "Přidat", | ||||
|     "Add New Monitor": "Přidat nový dohled", | ||||
|     "Quick Stats": "Rychlé statistiky", | ||||
|     Up: "Běží", | ||||
|     Down: "Nedostupný", | ||||
|     Pending: "Čekám", | ||||
|     Unknown: "Neznámý", | ||||
|     Pause: "Pozastavit", | ||||
|     Name: "Název", | ||||
|     Status: "Stav", | ||||
|     DateTime: "DateTime", | ||||
|     Message: "Zpráva", | ||||
|     "No important events": "Žádné důležité události", | ||||
|     Resume: "Pokračovat", | ||||
|     Edit: "Změnit", | ||||
|     Delete: "Vymazat", | ||||
|     Current: "Aktuální", | ||||
|     Uptime: "Doba provozu", | ||||
|     "Cert Exp.": "Platnost certifikátu", | ||||
|     days: "dny/í", | ||||
|     day: "den", | ||||
|     "-day": "-dní", | ||||
|     hour: "hodina", | ||||
|     "-hour": "-hodin", | ||||
|     Response: "Odpověď", | ||||
|     Ping: "Ping", | ||||
|     "Monitor Type": "Typ dohledu", | ||||
|     Keyword: "Klíčové slovo", | ||||
|     "Friendly Name": "Obecný název", | ||||
|     URL: "URL", | ||||
|     Hostname: "Adresa serveru", | ||||
|     Port: "Port", | ||||
|     "Heartbeat Interval": "Heartbeat interval", | ||||
|     Retries: "Počet pokusů", | ||||
|     "Heartbeat Retry Interval": "Interval opakování prezenčního signálu", | ||||
|     Advanced: "Rozšířené", | ||||
|     "Upside Down Mode": "Inverzní režim", | ||||
|     "Max. Redirects": "Max. Přesměrování", | ||||
|     "Accepted Status Codes": "Akceptované stavové kódy", | ||||
|     "Push URL": "Push URL", | ||||
|     needPushEvery: "Tuto URL adresu byste měli volat každých {0} sekund.", | ||||
|     pushOptionalParams: "Volitelné parametry: {0}", | ||||
|     Save: "Uložit", | ||||
|     Notifications: "Oznámení", | ||||
|     "Not available, please setup.": "Není k dispozici, prosím nastavte.", | ||||
|     "Setup Notification": "Nastavení oznámení", | ||||
|     Light: "Světlý", | ||||
|     Dark: "Tmavý", | ||||
|     Auto: "Automaticky", | ||||
|     "Theme - Heartbeat Bar": "Motiv – Heartbeat panel", | ||||
|     Normal: "Normální", | ||||
|     Bottom: "Dole", | ||||
|     None: "Žádné", | ||||
|     Timezone: "Časové pásmo", | ||||
|     "Search Engine Visibility": "Viditelnost pro vyhledávače", | ||||
|     "Allow indexing": "Povolit indexování", | ||||
|     "Discourage search engines from indexing site": "Zabránit vyhledávačům v indexování stránky", | ||||
|     "Change Password": "Změnit heslo", | ||||
|     "Current Password": "Aktuální heslo", | ||||
|     "New Password": "Nové heslo", | ||||
|     "Repeat New Password": "Znovu zadat nové heslo", | ||||
|     "Update Password": "Aktualizovat heslo", | ||||
|     "Disable Auth": "Deaktivovat ověřování", | ||||
|     "Enable Auth": "Povolit ověřování", | ||||
|     Logout: "Odhlášení", | ||||
|     Leave: "Odejít", | ||||
|     "I understand, please disable": "Rozumím, chci ji deaktivovat", | ||||
|     Confirm: "Potvrzení", | ||||
|     Yes: "Ano", | ||||
|     No: "Ne", | ||||
|     Username: "Uživatelské jméno", | ||||
|     Password: "Heslo", | ||||
|     "Remember me": "Zapamatovat si mě", | ||||
|     Login: "Přihlášení", | ||||
|     "No Monitors, please": "Žádné dohledy, prosím", | ||||
|     "add one": "přidat jeden", | ||||
|     "Notification Type": "Typ oznámení", | ||||
|     Email: "E-mail", | ||||
|     Test: "Test", | ||||
|     "Certificate Info": "Informace o certifikátu", | ||||
|     "Resolver Server": "Resolver Server", | ||||
|     "Resource Record Type": "Typ záznamu o prostředku", | ||||
|     "Last Result": "Poslední výsledek", | ||||
|     "Create your admin account": "Vytvořit účet administrátora", | ||||
|     "Repeat Password": "Znovu zadat heslo", | ||||
|     "Import Backup": "Importovat zálohu", | ||||
|     "Export Backup": "Exportovat zálohu", | ||||
|     Export: "Exportovat", | ||||
|     Import: "Importovat", | ||||
|     respTime: "Odezva Čas (ms)", | ||||
|     notAvailableShort: "N/A", | ||||
|     "Default enabled": "Standardně povoleno", | ||||
|     "Apply on all existing monitors": "Použít pro všechny existující dohledy", | ||||
|     Create: "Vytvořit", | ||||
|     "Clear Data": "Vymazat data", | ||||
|     Events: "Události", | ||||
|     Heartbeats: "Heartbeaty", | ||||
|     "Auto Get": "Získat automaticky", | ||||
|     backupDescription: "Všechny dohledy a oznámení můžete zálohovat do souboru ve formátu JSON.", | ||||
|     backupDescription2: "Poznámka: Nezahrnuje historii a data událostí.", | ||||
|     backupDescription3: "Součástí exportovaného souboru jsou citlivá data jako tokeny oznámení; export si prosím bezpečně uložte.", | ||||
|     alertNoFile: "Vyberte soubor, který chcete importovat.", | ||||
|     alertWrongFileType: "Vyberte soubor ve formátu JSON.", | ||||
|     "Clear all statistics": "Vymazat všechny statistiky", | ||||
|     "Skip existing": "Přeskočit existující", | ||||
|     Overwrite: "Přepsat", | ||||
|     Options: "Možnosti", | ||||
|     "Keep both": "Ponechat obojí", | ||||
|     "Verify Token": "Ověřit token", | ||||
|     "Setup 2FA": "Nastavení 2FA", | ||||
|     "Enable 2FA": "Povolit 2FA", | ||||
|     "Disable 2FA": "Deaktivovat 2FA", | ||||
|     "2FA Settings": "Nastavení 2FA", | ||||
|     "Two Factor Authentication": "Dvoufaktorová autentifikace", | ||||
|     Active: "Zapnuto", | ||||
|     Inactive: "Neaktivní", | ||||
|     Token: "Token", | ||||
|     "Show URI": "Zobrazit URI", | ||||
|     Tags: "Štítky", | ||||
|     "Add New below or Select...": "Níže přidejte nový nebo vyberte existující…", | ||||
|     "Tag with this name already exist.": "Štítek s tímto názvem již existuje.", | ||||
|     "Tag with this value already exist.": "Štítek touto hodnotou již existuje.", | ||||
|     color: "barva", | ||||
|     "value (optional)": "hodnota (volitelné)", | ||||
|     Gray: "Šedá", | ||||
|     Red: "Červená", | ||||
|     Orange: "Oranžová", | ||||
|     Green: "Zelená", | ||||
|     Blue: "Modrá", | ||||
|     Indigo: "Indigo", | ||||
|     Purple: "Purpurová", | ||||
|     Pink: "Růžová", | ||||
|     "Search...": "Hledat…", | ||||
|     "Avg. Ping": "Průměr Ping", | ||||
|     "Avg. Response": "Průměr Odpověď", | ||||
|     "Entry Page": "Vstupní stránka", | ||||
|     statusPageNothing: "Nic tady není, přidejte prosím skupinu nebo dohled.", | ||||
|     "No Services": "Žádné služby", | ||||
|     "All Systems Operational": "Všechny systémy běží", | ||||
|     "Partially Degraded Service": "Částečně zhoršená služba", | ||||
|     "Degraded Service": "Zhoršená služba", | ||||
|     "Add Group": "Přidat skupinu", | ||||
|     "Add a monitor": "Přidání dohledu", | ||||
|     "Edit Status Page": "Upravit stavovou stránku", | ||||
|     "Go to Dashboard": "Přejít na nástěnku", | ||||
|     "Status Page": "Stavová stránka", | ||||
|     defaultNotificationName: "Moje {notification} upozornění ({číslo})", | ||||
|     here: "sem", | ||||
|     Required: "Vyžadováno", | ||||
|     telegram: "Telegram", | ||||
|     "Bot Token": "Token robota", | ||||
|     wayToGetTelegramToken: "Token můžete získat od {0}.", | ||||
|     "Chat ID": "ID chatu", | ||||
|     supportTelegramChatID: "Podpora přímého chatu / skupiny / ID chatu kanálu", | ||||
|     wayToGetTelegramChatID: "ID chatu můžete získat tak, že robotovi zašlete zprávu a přejdete na tuto adresu URL, kde zobrazíte chat_id:", | ||||
|     "YOUR BOT TOKEN HERE": "YOUR BOT TOKEN HERE", | ||||
|     chatIDNotFound: "ID chatu nebylo nalezeno; nejprve tomuto robotovi zašlete zprávu", | ||||
|     webhook: "Webhook", | ||||
|     "Post URL": "URL adresa příspěvku", | ||||
|     "Content Type": "Typ obsahu", | ||||
|     webhookJsonDesc: "{0} je vhodný pro všechny moderní servery HTTP, jako je Express.js", | ||||
|     webhookFormDataDesc: "{multipart} je vhodné pro PHP. JSON bude nutné analyzovat prostřednictvím {decodeFunction}", | ||||
|     smtp: "E-mail (SMTP)", | ||||
|     secureOptionNone: "Žádné / STARTTLS (25, 587)", | ||||
|     secureOptionTLS: "TLS (465)", | ||||
|     "Ignore TLS Error": "Ignorovat chybu TLS", | ||||
|     "From Email": "Odesílatel", | ||||
|     emailCustomSubject: "Vlastní předmět", | ||||
|     "To Email": "Příjemce", | ||||
|     smtpCC: "Kopie", | ||||
|     smtpBCC: "Skrytá kopie", | ||||
|     discord: "Discord", | ||||
|     "Discord Webhook URL": "Discord Webhook URL", | ||||
|     wayToGetDiscordURL: "Získáte tak, že přejdete do Nastavení serveru - > Integrace - > Vytvořit Webhook", | ||||
|     "Bot Display Name": "Zobrazované jméno robota", | ||||
|     "Prefix Custom Message": "Předpona vlastní zprávy", | ||||
|     "Hello @everyone is...": "Dobrý den, {'@'}všichni jsou…", | ||||
|     teams: "Microsoft Teams", | ||||
|     "Webhook URL": "URL adresa webhooku", | ||||
|     wayToGetTeamsURL: "Informace o tom, jak vytvořit URL adresu webhooku naleznete {0}.", | ||||
|     signal: "Signal", | ||||
|     Number: "Číslo", | ||||
|     Recipients: "Příjemci", | ||||
|     needSignalAPI: "Musíte mít Signal klienta s REST API.", | ||||
|     wayToCheckSignalURL: "Pro zobrazení instrukcí, jak službu nastavit, přejděte na následující adresu:", | ||||
|     signalImportant: "Důležité V seznamu příjemců není možné současně použít skupiny a čísla!", | ||||
|     gotify: "Gotify", | ||||
|     "Application Token": "Token aplikace", | ||||
|     "Server URL": "URL adresa serveru", | ||||
|     Priority: "Priorita", | ||||
|     slack: "Slack", | ||||
|     "Icon Emoji": "Ikona smajlíka", | ||||
|     "Channel Name": "Název kanálu", | ||||
|     "Uptime Kuma URL": "Uptime Kuma URL", | ||||
|     aboutWebhooks: "Více informací o Webhoocích naleznete na adrese: {0}", | ||||
|     aboutChannelName: "Pro vynechání Webhook kanálu zadejte jeho název do pole Název kanálu {0}. Příklad: #jiny-kanal", | ||||
|     aboutKumaURL: "Pokud ponecháte pole URL adresa Uptime Kuma prázdné, použije se domovská stránka GitHub projektu.", | ||||
|     emojiCheatSheet: "Tahák smajlíků: {0}", | ||||
|     "rocket.chat": "Rocket.Chat", | ||||
|     pushover: "Pushover", | ||||
|     pushy: "Pushy", | ||||
|     octopush: "Octopush", | ||||
|     promosms: "PromoSMS", | ||||
|     clicksendsms: "ClickSend SMS", | ||||
|     lunasea: "LunaSea", | ||||
|     apprise: "Apprise (podpora více než 50 oznamovacích služeb)", | ||||
|     GoogleChat: "Google Chat (pouze Google Workspace)", | ||||
|     pushbullet: "Pushbullet", | ||||
|     line: "Line Messenger", | ||||
|     mattermost: "Mattermost", | ||||
|     "User Key": "Klíč uživatele", | ||||
|     Device: "Zařízení", | ||||
|     "Message Title": "Nadpis zprávy", | ||||
|     "Notification Sound": "Zvuk oznámení", | ||||
|     "More info on:": "Více informací naleznete na adrese: {0}", | ||||
|     pushoverDesc1: "Výchozí časový limit pro emergency prioritu (2) je 30 sekund mezi opakovanými pokusy a vyprší po 1 hodině.", | ||||
|     pushoverDesc2: "Pokud chcete odesílat oznámení do různých zařízení, vyplňte pole Zařízení.", | ||||
|     "SMS Type": "Typ SMS", | ||||
|     octopushTypePremium: "Premium (rychlé – doporučeno pro upozornění)", | ||||
|     octopushTypeLowCost: "Nízké náklady (pomalé – někdy blokované operátorem)", | ||||
|     checkPrice: "Ceny {0} zjistíte na adrese:", | ||||
|     apiCredentials: "API přihlašovací údaje", | ||||
|     octopushLegacyHint: "Používáte starší verzi Octopush (2011-2020) nebo novou verzi?", | ||||
|     "Check octopush prices": "Ceny octopush naleznete na adrese {0}.", | ||||
|     octopushPhoneNumber: "Telefonní číslo (v mezinárodním formátu, např: +42012345678) ", | ||||
|     octopushSMSSender: "Odesílatel SMS: 3-11 alfanumerických znaků a mezera (a-zA-Z0-9)", | ||||
|     "LunaSea Device ID": "ID zařízení LunaSea", | ||||
|     "Apprise URL": "Apprise URL", | ||||
|     "Example:": "Příklad: {0}", | ||||
|     "Read more:": "Více informací: {0}", | ||||
|     "Status:": "Stav: {0}", | ||||
|     "Read more": "Více informací", | ||||
|     appriseInstalled: "Apprise je nainstalován.", | ||||
|     appriseNotInstalled: "Apprise není nainstalován. {0}", | ||||
|     "Access Token": "Přístupový token", | ||||
|     "Channel access token": "Přístupový token ke kanálu", | ||||
|     "Line Developers Console": "Konzole Line Developers", | ||||
|     lineDevConsoleTo: "Konzole Line Developers - {0}", | ||||
|     "Basic Settings": "Obecné nastavení", | ||||
|     "User ID": "ID uživatele", | ||||
|     "Messaging API": "Messaging API", | ||||
|     wayToGetLineChannelToken: "Nejprve otevřete {0}, vytvořte poskytovatele a kanál (Messaging API). Poté můžete získat přístupový token ke kanálu a ID uživatele, v sekci uvedené výše.", | ||||
|     "Icon URL": "URL adresa ikony", | ||||
|     aboutIconURL: "Pro přepsání výchozího profilového obrázku můžete do pole \"URL adresa ikony\" zadat odkaz na obrázek. Nebude použito, pokud je nastavena ikona smajlíka.", | ||||
|     aboutMattermostChannelName: "Výchozí kanál, do kterého jsou zasílány Webhook příspěvky, můžete přepsat zadáním názvu kanálu do pole \"Název kanálu\". Tato možnost musí být povolena v nastavení Mattermost Webhooku. Příklad: #jiny-kanal", | ||||
|     matrix: "Matrix", | ||||
|     promosmsTypeEco: "SMS ECO – levné, ale pomalé a často přetížené. Omezeno pouze na polské příjemce.", | ||||
|     promosmsTypeFlash: "SMS FLASH –zpráva se automaticky zobrazí na zařízení příjemce. Omezeno pouze na polské příjemce.", | ||||
|     promosmsTypeFull: "SMS FULL – prémiová úroveň SMS. Můžete definovat odesílatele (vyžadována registrace jména). Spolehlivý pro výstrahy.", | ||||
|     promosmsTypeSpeed: "SMS SPEED – nejvyšší priorita v systému. Velmi rychlé a spolehlivé, ale nákladné (přibližně dvojnásobek ceny SMS FULL).", | ||||
|     promosmsPhoneNumber: "Telefonní číslo (polští příjemci mohou vynechat telefonní předvolbu)", | ||||
|     promosmsSMSSender: "Odesílatel SMS: Předem zaregistrovaný název nebo jeden z výchozích: InfoSMS, SMS Info, MaxSMS, INFO, SMS", | ||||
|     "Feishu WebHookUrl": "Feishu WebHookURL", | ||||
|     matrixHomeserverURL: "URL adresa domácího serveru (s http(s):// a volitelně portem)", | ||||
|     "Internal Room Id": "ID interní místnosti", | ||||
|     matrixDesc1: "ID interní místnosti naleznete v Matrix klientovi v rozšířeném nastavení místnosti. Mělo by být ve tvaru !QMdRCpUIfLwsfjxye6:home.server.", | ||||
|     matrixDesc2: "Důrazně doporučujeme vytvořit nového uživatele a nepoužívat váš vlastní přístupový token uživatele Matrix. Pomocí něj je možné získat přístup k vašemu účtu a všem místnostem, ke kterým jste se připojili. Místo toho vytvořte nového uživatele a pozvěte jej pouze do místnosti, do které chcete oznámení dostávat. Přístupový token můžete získat spuštěním {0}", | ||||
|     Method: "Metoda", | ||||
|     Body: "Tělo", | ||||
|     Headers: "Hlavičky", | ||||
|     PushUrl: "Push URL", | ||||
|     HeadersInvalidFormat: "The request headers are not valid JSON: ", | ||||
|     BodyInvalidFormat: "The request body is not valid JSON: ", | ||||
|     "Monitor History": "Historie dohledu", | ||||
|     clearDataOlderThan: "Historie dohledu bude uchovávána po dobu {0} dní.", | ||||
|     PasswordsDoNotMatch: "Hesla se neshodují.", | ||||
|     records: "záznamů", | ||||
|     "One record": "Jeden záznam", | ||||
|     steamApiKeyDescription: "For monitoring a Steam Game Server you need a Steam Web-API key. You can register your API key here: ", | ||||
|     "Current User": "Aktuálně přihlášený uživatel", | ||||
|     recent: "Poslední", | ||||
|     Done: "Hotovo", | ||||
|     Info: "Informace", | ||||
|     Security: "Bezpečnost", | ||||
|     "Steam API Key": "API klíč služby Steam", | ||||
|     "Shrink Database": "Zmenšit databázi", | ||||
|     "Pick a RR-Type...": "Vyberte typ záznamu o prostředku…", | ||||
|     "Pick Accepted Status Codes...": "Vyberte stavové kódy, které chcete akceptovat…", | ||||
|     Default: "Standardní", | ||||
|     "HTTP Options": "Možnosti protokolu HTTP", | ||||
|     "Create Incident": "Vytvořit incident", | ||||
|     Title: "Předmět", | ||||
|     Content: "Obsah", | ||||
|     Style: "Styl", | ||||
|     info: "informace", | ||||
|     warning: "upozornění", | ||||
|     danger: "riziko", | ||||
|     primary: "primární", | ||||
|     light: "světlý", | ||||
|     dark: "tmavý", | ||||
|     Post: "Publikovat", | ||||
|     "Please input title and content": "Zadejte prosím název a obsah", | ||||
|     Created: "Vytvořen", | ||||
|     "Last Updated": "Poslední aktualizace", | ||||
|     Unpin: "Odepnout", | ||||
|     "Switch to Light Theme": "Přepnout na světlý motiv", | ||||
|     "Switch to Dark Theme": "Přepnutí na tmavý motiv", | ||||
|     "Show Tags": "Zobrazit štítky", | ||||
|     "Hide Tags": "Skrýt štítky", | ||||
|     Description: "Popis", | ||||
|     "No monitors available.": "Není dostupný žádný dohled.", | ||||
|     "Add one": "Přidat jeden", | ||||
|     "No Monitors": "Žádný dohled", | ||||
|     "Untitled Group": "Skupina bez názvu", | ||||
|     Services: "Služby", | ||||
|     Discard: "Zahodit", | ||||
|     Cancel: "Zrušit", | ||||
|     "Powered by": "Poskytuje", | ||||
|     shrinkDatabaseDescription: "Pomocí této možnosti provedete příkaz VACUUM nad SQLite databází. Pokud byla databáze vytvořena po vydání verze 1.10.0, AUTO_VACUUM je již povolena a tato akce není vyžadována.", | ||||
|     serwersms: "SerwerSMS.pl", | ||||
|     serwersmsAPIUser: "API uživatelské jméno (včetně předpony webapi_)", | ||||
|     serwersmsAPIPassword: "API heslo", | ||||
|     serwersmsPhoneNumber: "Telefonní číslo", | ||||
|     serwersmsSenderName: "Odesílatel SMS (registrováno prostřednictvím zákaznického portálu)", | ||||
|     "stackfield": "Stackfield", | ||||
|     smtpDkimSettings: "Nastavení DKIM", | ||||
|     smtpDkimDesc: "Informace o použití naleznete v {0} Nodemailer DKIM.", | ||||
|     documentation: "dokumentaci", | ||||
|     smtpDkimDomain: "Název domény", | ||||
|     smtpDkimKeySelector: "Selector klíče", | ||||
|     smtpDkimPrivateKey: "Privátní klíč", | ||||
|     smtpDkimHashAlgo: "Hashovací algoritmus (volitelné)", | ||||
|     smtpDkimheaderFieldNames: "Podepisovat tyto hlavičky (volitelné)", | ||||
|     smtpDkimskipFields: "Nepodepisovat tyto hlavičky (volitelné)", | ||||
| }; | ||||
| @@ -1,7 +1,7 @@ | ||||
| export default { | ||||
|     languageName: "Danish (Danmark)", | ||||
|     Settings: "Indstillinger", | ||||
|     Dashboard: "Dashboard", | ||||
|     Dashboard: "Betjeningspanel", | ||||
|     "New Update": "Opdatering tilgængelig", | ||||
|     Language: "Sprog", | ||||
|     Appearance: "Udseende", | ||||
| @@ -98,7 +98,7 @@ export default { | ||||
|     keywordDescription: "Søg efter et søgeord i almindelig HTML- eller JSON -output. Bemærk, at der skelnes mellem store og små bogstaver.", | ||||
|     deleteMonitorMsg: "Er du sikker på, at du vil slette overvågeren?", | ||||
|     deleteNotificationMsg: "Er du sikker på, at du vil slette denne underretning for alle overvågere? ", | ||||
|     resoverserverDescription: "Cloudflare er standardserveren, den kan til enhver tid ændres.", | ||||
|     resolverserverDescription: "Cloudflare er standardserveren, den kan til enhver tid ændres.", | ||||
|     "Resolver Server": "Navne-server", | ||||
|     rrtypeDescription: "Vælg den type RR, du vil overvåge.", | ||||
|     "Last Result": "Seneste resultat", | ||||
| @@ -110,11 +110,11 @@ export default { | ||||
|     notAvailableShort: "N/A", | ||||
|     Create: "Opret", | ||||
|     clearEventsMsg: "Er du sikker på vil slette alle events for denne Overvåger?", | ||||
|     clearHeartbeatsMsg: "Er du sikker på vil slette alle heartbeats for denne Overvåger?", | ||||
|     clearHeartbeatsMsg: "Er du sikker på vil slette alle hjerteslag for denne Overvåger?", | ||||
|     confirmClearStatisticsMsg: "Vil du helt sikkert slette ALLE statistikker?", | ||||
|     "Clear Data": "Ryd Data", | ||||
|     Events: "Events", | ||||
|     Heartbeats: "Heartbeats", | ||||
|     Heartbeats: "Hjerteslag", | ||||
|     "Auto Get": "Auto-hent", | ||||
|     enableDefaultNotificationDescription: "For hver ny overvåger aktiveres denne underretning som standard. Du kan stadig deaktivere underretningen separat for hver skærm.", | ||||
|     "Default enabled": "Standard aktiveret", | ||||
| @@ -145,14 +145,14 @@ export default { | ||||
|     retryCheckEverySecond: "Prøv igen hvert {0} sekund.", | ||||
|     importHandleDescription: "Vælg 'Spring over eksisterende', hvis du vil springe over hver overvåger eller underretning med samme navn. 'Overskriv' sletter alle eksisterende overvågere og underretninger.", | ||||
|     confirmImportMsg: "Er du sikker på at importere sikkerhedskopien? Sørg for, at du har valgt den rigtige importindstilling.", | ||||
|     "Heartbeat Retry Interval": "Heartbeat Gentagelsesinterval", | ||||
|     "Heartbeat Retry Interval": "Hjerteslag Gentagelsesinterval", | ||||
|     "Import Backup": "Importer Backup", | ||||
|     "Export Backup": "Eksporter Backup", | ||||
|     "Skip existing": "Spring over eksisterende", | ||||
|     Overwrite: "Overskriv", | ||||
|     Options: "Valgmuligheder", | ||||
|     "Keep both": "Behold begge", | ||||
|     Tags: "Tags", | ||||
|     Tags: "Etiketter", | ||||
|     "Add New below or Select...": "Tilføj Nyt nedenfor eller Vælg ...", | ||||
|     "Tag with this name already exist.": "Et Tag med dette navn findes allerede.", | ||||
|     "Tag with this value already exist.": "Et Tag med denne værdi findes allerede.", | ||||
| @@ -178,8 +178,8 @@ export default { | ||||
|     "Add Group": "Tilføj Gruppe", | ||||
|     "Add a monitor": "Tilføj en Overvåger", | ||||
|     "Edit Status Page": "Rediger Statusside", | ||||
|     "Go to Dashboard": "Gå til Dashboard", | ||||
|     "Status Page": "Status Page", | ||||
|     "Go to Dashboard": "Gå til Betjeningspanel", | ||||
|     "Status Page": "Statusside", | ||||
|     telegram: "Telegram", | ||||
|     webhook: "Webhook", | ||||
|     smtp: "Email (SMTP)", | ||||
| @@ -194,8 +194,162 @@ export default { | ||||
|     octopush: "Octopush", | ||||
|     promosms: "PromoSMS", | ||||
|     lunasea: "LunaSea", | ||||
|     apprise: "Apprise (Support 50+ Notification services)", | ||||
|     apprise: "Apprise (Understøtter 50+ Notifikationstjenester)", | ||||
|     pushbullet: "Pushbullet", | ||||
|     line: "Line Messenger", | ||||
|     mattermost: "Mattermost", | ||||
|     "Primary Base URL": "Primær Basis-URL", | ||||
|     "Push URL": "Push URL", | ||||
|     needPushEvery: "Du bør kalde denne webadresse hvert {0} sekund.", | ||||
|     pushOptionalParams: "Valgfrie parametre: {0}", | ||||
|     defaultNotificationName: "Min {notification} Advarsel ({number})", | ||||
|     here: "her", | ||||
|     Required: "Påkrævet", | ||||
|     "Bot Token": "Bot Token", | ||||
|     wayToGetTelegramToken: "Du kan få et token fra {0}.", | ||||
|     "Chat ID": "Chat ID", | ||||
|     supportTelegramChatID: "Support Direct Chat / Group / Channel's Chat ID", | ||||
|     wayToGetTelegramChatID: "Du kan få dit chat-ID ved at sende en besked til bot'en og gå til denne URL for at se chat_id'et:", | ||||
|     "YOUR BOT TOKEN HERE": "DIT BOT TOKEN HER", | ||||
|     chatIDNotFound: "Chat-ID blev ikke fundet; send venligst en besked til denne bot først ", | ||||
|     "Post URL": "Post URL", | ||||
|     "Content Type": "Indholdstype", | ||||
|     webhookJsonDesc: "{0} er god til alle moderne HTTP-servere som f.eks Express.js", | ||||
|     webhookFormDataDesc: "{multipart} er god til PHP. JSON'en skal parses med {decodeFunction}", | ||||
|     secureOptionNone: "Ingen / STARTTLS (25, 587)", | ||||
|     secureOptionTLS: "TLS (465)", | ||||
|     "Ignore TLS Error": "Ignorer TLS-fejl", | ||||
|     "From Email": "Afsender Email", | ||||
|     emailCustomSubject: "Brugerdefineret Emne", | ||||
|     "To Email": "Modtager Email", | ||||
|     smtpCC: "CC", | ||||
|     smtpBCC: "BCC", | ||||
|     "Discord Webhook URL": "Discord Webhook URL", | ||||
|     wayToGetDiscordURL: "Du kan få dette ved at gå til Serverindstillinger -> Integrationer -> Opret webhook ", | ||||
|     "Bot Display Name": "Bot Visningsnavn", | ||||
|     "Prefix Custom Message": "Præfiks Brugerdefineret Besked", | ||||
|     "Hello @everyone is...": "Hello {'@'}everyone is...", | ||||
|     "Webhook URL": "Webhook URL", | ||||
|     wayToGetTeamsURL: "Du kan lære, hvordan du laver en webhook URL {0}.", | ||||
|     Number: "Nummer", | ||||
|     Recipients: "Modtagere", | ||||
|     needSignalAPI: "Du skal have en Signal-klient med REST API.", | ||||
|     wayToCheckSignalURL: "Du kan tjekke denne URL for at se, hvordan du konfigurerer en:", | ||||
|     signalImportant: "VIGTIGT: Du kan ikke blande grupper og numre i modtagere!", | ||||
|     "Application Token": "Program Token", | ||||
|     "Server URL": "Server URL", | ||||
|     Priority: "Prioritet", | ||||
|     "Icon Emoji": "Icon Emoji", | ||||
|     "Channel Name": "Kanalnavn", | ||||
|     "Uptime Kuma URL": "Uptime Kuma URL", | ||||
|     aboutWebhooks: "Mere info om Webhooks på: {0}", | ||||
|     aboutChannelName: "Indtast kanalnavnet i {0} Kanalnavn feltet, hvis du vil omgå Webhook-kanalen. Eks: #anden-kanal", | ||||
|     aboutKumaURL: "Hvis du efterlader Uptime Kuma URL-feltet tomt, vil det som standard gå til projektets GitHub-siden.", | ||||
|     emojiCheatSheet: "Emoji cheat sheet: {0}", | ||||
|     clicksendsms: "ClickSend SMS", | ||||
|     "User Key": "Bruger-Nøgle", | ||||
|     Device: "Enhed", | ||||
|     "Message Title": "Besked Titel", | ||||
|     "Notification Sound": "Notifikationslyd", | ||||
|     "More info on:": "Mere info på: {0}", | ||||
|     pushoverDesc1: "Nødprioritet (2) har som standard 30 sekunders timeout mellem genforsøg og udløber efter 1 time.", | ||||
|     pushoverDesc2: "Hvis du vil sende meddelelser til forskellige enheder, skal du udfylde feltet Enhed.", | ||||
|     "SMS Type": "SMS Type", | ||||
|     octopushTypePremium: "Premium (Hurtig - anbefales til advarsel)", | ||||
|     octopushTypeLowCost: "Lavpris (Langsom - nogle gange blokeret af operatøren)", | ||||
|     checkPrice: "Tjek {0} priser:", | ||||
|     apiCredentials: "API legitimationsoplysninger", | ||||
|     octopushLegacyHint: "Bruger du den ældre version af Octopush (2011-2020) eller den nye version?", | ||||
|     "Check octopush prices": "Tjek octopush priser {0}.", | ||||
|     octopushPhoneNumber: "Telefonnummer (intl format, f.eks : +4512345678) ", | ||||
|     octopushSMSSender: "SMS Afsender Navn : 3-11 alfanumeriske tegn og mellemrum (a-zA-Z0-9)", | ||||
|     "LunaSea Device ID": "LunaSea Enhed-ID", | ||||
|     "Apprise URL": "Apprise URL", | ||||
|     "Example:": "Eksempel: {0}", | ||||
|     "Read more:": "Læs mere: {0}", | ||||
|     "Status:": "Status: {0}", | ||||
|     "Read more": "Læs mere", | ||||
|     appriseInstalled: "Apprise er installeret.", | ||||
|     appriseNotInstalled: "Apprise er ikke installeret. {0}", | ||||
|     "Access Token": "Access Token", | ||||
|     "Channel access token": "kanaladgangstoken", | ||||
|     "Line Developers Console": "Line Udviklerkonsol", | ||||
|     lineDevConsoleTo: "Line Udviklerkonsol - {0}", | ||||
|     "Basic Settings": "Basisindstillinger", | ||||
|     "User ID": "Bruger-ID", | ||||
|     "Messaging API": "Messaging API", | ||||
|     wayToGetLineChannelToken: "Tilgå først {0}, opret en udbyder og kanal (Messaging API), så kan du få kanaladgangstoken'et og bruger-ID'et fra de ovennævnte menupunkter.", | ||||
|     "Icon URL": "Ikon URL", | ||||
|     aboutIconURL: "Du kan angive et link til et billede i \"Ikon URL\" for at tilsidesætte standardprofilbilledet. Vil ikke blive brugt, hvis Ikon Emoji er angivet.", | ||||
|     aboutMattermostChannelName: "Du kan tilsidesætte standardkanalen, som Webhoo'en sender til ved at indtaste kanalnavnet i feltet \"Kanalnavn\". Dette skal aktiveres i Mattermost Webhook-indstillingerne. Eks: #anden-kanal", | ||||
|     matrix: "Matrix", | ||||
|     promosmsTypeEco: "SMS ECO - billig, men langsom og ofte overbelastet. Begrænset kun til polske modtagere.", | ||||
|     promosmsTypeFlash: "SMS FLASH - Beskeden vises automatisk på modtagerenheden. Begrænset kun til polske modtagere.", | ||||
|     promosmsTypeFull: "SMS FULL - Premium-niveau af SMS, Du kan bruge dit \"Sender Name\" (Du skal først registrere navn). Pålidelig til advarsler.", | ||||
|     promosmsTypeSpeed: "SMS SPEED - Højeste prioritet i systemet. Meget hurtig og pålidelig, men dyr (ca. to gange af SMS FULL pris).", | ||||
|     promosmsPhoneNumber: "Telefonnummer (polske numre behøver ikke angive områdenumre)", | ||||
|     promosmsSMSSender: "SMS Sender Name : Forudregistreret navn eller en af standarderne: InfoSMS, SMS Info, MaxSMS, INFO, SMS", | ||||
|     "Feishu WebHookUrl": "Feishu WebHookURL", | ||||
|     matrixHomeserverURL: "Hjemmeserver-URL (med http(s):// og eventuel port)", | ||||
|     "Internal Room Id": "Intern Rum-ID", | ||||
|     matrixDesc1: "Du kan finde det interne rum-ID ved at se i det avancerede afsnit af rumindstillingerne i din Matrix-klient. Det skulle ligne !QMdRCpUIfLwsfjxye6:home.server.", | ||||
|     matrixDesc2: "Det anbefales stærkt, at du opretter en ny bruger og ikke bruger din egen Matrix-brugers adgangstoken, da det giver fuld adgang til din konto og alle de rum, du har tilsluttet dig. I stedet skal du oprette en ny bruger og kun invitere den til det rum, du vil modtage meddelelsen i. Du kan få adgangstokenet ved at køre {0}", | ||||
|     Method: "Metode", | ||||
|     Body: "Body", | ||||
|     Headers: "Headers", | ||||
|     PushUrl: "Push URL", | ||||
|     HeadersInvalidFormat: "\"request headers\"-erne er ikke gyldige JSON: ", | ||||
|     BodyInvalidFormat: "\"request body\"-en er ikke gyldige JSON: ", | ||||
|     "Monitor History": "Overvåger Historik", | ||||
|     clearDataOlderThan: "Gem overvågningshistorikdata i {0} dage.", | ||||
|     PasswordsDoNotMatch: "Adgangskoderne stemmer ikke overens.", | ||||
|     records: "forekomster", | ||||
|     "One record": "Én forekomst", | ||||
|     steamApiKeyDescription: "For at overvåge en Steam Game Server skal du bruge en Steam Web-API nøgle. Du kan registrere din API-nøgle her: ", | ||||
|     "Current User": "Nuværende Bruger", | ||||
|     recent: "Seneste", | ||||
|     Done: "Færdig", | ||||
|     Info: "Info", | ||||
|     Security: "Sikkerhed", | ||||
|     "Steam API Key": "Steam API-nøgle", | ||||
|     "Shrink Database": "Krymp Database", | ||||
|     "Pick a RR-Type...": "Vælg en RR-Type...", | ||||
|     "Pick Accepted Status Codes...": "Vælg Accepterede Statuskoder...", | ||||
|     Default: "Standard", | ||||
|     "HTTP Options": "HTTP Valgmuligheder", | ||||
|     "Create Incident": "Opret Annoncering", | ||||
|     Title: "Titel", | ||||
|     Content: "Indhold", | ||||
|     Style: "Type", | ||||
|     info: "info", | ||||
|     warning: "advarsel", | ||||
|     danger: "fare", | ||||
|     primary: "primær", | ||||
|     light: "lys", | ||||
|     dark: "mørk", | ||||
|     Post: "Udgiv", | ||||
|     "Please input title and content": "Indtast venligst titel og indhold", | ||||
|     Created: "Oprettet", | ||||
|     "Last Updated": "Sidst Opdateret", | ||||
|     Unpin: "Frigør", | ||||
|     "Switch to Light Theme": "Skift til Lys Tema", | ||||
|     "Switch to Dark Theme": "Skift til Mørkt Tema", | ||||
|     "Show Tags": "Vis Etiketter", | ||||
|     "Hide Tags": "Skjul Etiketter", | ||||
|     Description: "Beskrivelse", | ||||
|     "No monitors available.": "No monitors available.", | ||||
|     "Add one": "Tilføj en", | ||||
|     "No Monitors": "Ingen Overvågere", | ||||
|     "Untitled Group": "Unavngivet Gruppe", | ||||
|     Services: "Tjenester", | ||||
|     Discard: "Kassér", | ||||
|     Cancel: "Annullér", | ||||
|     "Powered by": "Drevet af", | ||||
|     shrinkDatabaseDescription: "Udfør database VACUUM for SQLite. Hvis din database er oprettet efter 1.10.0, er AUTO_VACUUM allerede aktiveret, og denne handling er ikke nødvendig.", | ||||
|     serwersms: "SerwerSMS.pl", | ||||
|     serwersmsAPIUser: "API Brugernavn (inkl. webapi_ prefix)", | ||||
|     serwersmsAPIPassword: "API Adgangskode", | ||||
|     serwersmsPhoneNumber: "Telefonnummer", | ||||
|     serwersmsSenderName: "SMS Afsender Navn (registreret via kundeportal)", | ||||
|     stackfield: "Stackfield", | ||||
| }; | ||||
|   | ||||
| @@ -4,14 +4,14 @@ export default { | ||||
|     Dashboard: "Dashboard", | ||||
|     "New Update": "Update verfügbar", | ||||
|     Language: "Sprache", | ||||
|     Appearance: "Erscheinung", | ||||
|     Theme: "Thema", | ||||
|     Appearance: "Erscheinungsbild", | ||||
|     Theme: "Erscheinungsbild", | ||||
|     General: "Allgemein", | ||||
|     Version: "Version", | ||||
|     "Check Update On GitHub": "Auf GitHub nach Updates suchen", | ||||
|     List: "Liste", | ||||
|     Add: "Hinzufügen", | ||||
|     "Add New Monitor": "Neuer Monitor", | ||||
|     "Add New Monitor": "Neuen Monitor hinzufügen", | ||||
|     "Quick Stats": "Übersicht", | ||||
|     Up: "Aktiv", | ||||
|     Down: "Inaktiv", | ||||
| @@ -49,20 +49,20 @@ export default { | ||||
|     retriesDescription: "Maximale Anzahl von Wiederholungen, bevor der Dienst als inaktiv markiert und eine Benachrichtigung gesendet wird.", | ||||
|     Advanced: "Erweitert", | ||||
|     ignoreTLSError: "Ignoriere TLS-/SSL-Fehler von Webseiten", | ||||
|     "Upside Down Mode": "Invertierter Modus", | ||||
|     upsideDownModeDescription: "Im invertierten Modus wird der Dienst als inaktiv angezeigt, wenn er erreichbar ist.", | ||||
|     "Upside Down Mode": "Umgekehrter Modus", | ||||
|     upsideDownModeDescription: "Im umgekehrten Modus wird der Dienst als inaktiv angezeigt, wenn er erreichbar ist.", | ||||
|     "Max. Redirects": "Max. Weiterleitungen", | ||||
|     maxRedirectDescription: "Maximale Anzahl von Weiterleitungen, denen gefolgt werden soll. Auf 0 setzen, um Weiterleitungen zu deaktivieren.", | ||||
|     "Accepted Status Codes": "Erlaubte HTTP-Statuscodes", | ||||
|     acceptedStatusCodesDescription: "Wähle die Statuscodes aus, welche trotzdem als erfolgreich gewertet werden sollen.", | ||||
|     acceptedStatusCodesDescription: "Statuscodes auswählen, die als erfolgreiche Verbindung gelten sollen.", | ||||
|     Save: "Speichern", | ||||
|     Notifications: "Benachrichtigungen", | ||||
|     "Not available, please setup.": "Keine verfügbar, bitte einrichten.", | ||||
|     "Not available, please setup.": "Nicht verfügbar, bitte einrichten.", | ||||
|     "Setup Notification": "Benachrichtigung einrichten", | ||||
|     Light: "Hell", | ||||
|     Dark: "Dunkel", | ||||
|     Auto: "Auto", | ||||
|     "Theme - Heartbeat Bar": "Thema - Zeitleiste", | ||||
|     "Theme - Heartbeat Bar": "Erscheinungsbild - Zeitleiste", | ||||
|     Normal: "Normal", | ||||
|     Bottom: "Unten", | ||||
|     None: "Keine", | ||||
| @@ -71,15 +71,15 @@ export default { | ||||
|     "Allow indexing": "Indizierung zulassen", | ||||
|     "Discourage search engines from indexing site": "Halte Suchmaschinen von der Indexierung der Seite ab", | ||||
|     "Change Password": "Passwort ändern", | ||||
|     "Current Password": "Derzeitiges Passwort", | ||||
|     "Current Password": "Aktuelles Passwort", | ||||
|     "New Password": "Neues Passwort", | ||||
|     "Repeat New Password": "Neues Passwort wiederholen", | ||||
|     passwordNotMatchMsg: "Passwörter stimmen nicht überein. ", | ||||
|     passwordNotMatchMsg: "Passwörter stimmen nicht überein.", | ||||
|     "Update Password": "Passwort aktualisieren", | ||||
|     "Disable Auth": "Authentifizierung deaktivieren", | ||||
|     "Enable Auth": "Authentifizierung aktivieren", | ||||
|     Logout: "Ausloggen", | ||||
|     notificationDescription: "Weise den Monitor(en) eine Benachrichtigung zu, damit diese Funktion greift.", | ||||
|     notificationDescription: "Benachrichtigungen müssen einem Monitor zugewiesen werden, damit diese funktionieren.", | ||||
|     Leave: "Verlassen", | ||||
|     "I understand, please disable": "Ich verstehe, bitte deaktivieren", | ||||
|     Confirm: "Bestätigen", | ||||
| @@ -87,7 +87,7 @@ export default { | ||||
|     No: "Nein", | ||||
|     Username: "Benutzername", | ||||
|     Password: "Passwort", | ||||
|     "Remember me": "Passwort merken", | ||||
|     "Remember me": "Angemeldet bleiben", | ||||
|     Login: "Einloggen", | ||||
|     "No Monitors, please": "Keine Monitore, bitte", | ||||
|     "add one": "hinzufügen", | ||||
| @@ -98,7 +98,7 @@ export default { | ||||
|     keywordDescription: "Ein Suchwort in der HTML- oder JSON-Ausgabe finden. Bitte beachte: es wird zwischen Groß-/Kleinschreibung unterschieden.", | ||||
|     deleteMonitorMsg: "Bist du sicher, dass du den Monitor löschen möchtest?", | ||||
|     deleteNotificationMsg: "Möchtest du diese Benachrichtigung wirklich für alle Monitore löschen?", | ||||
|     resoverserverDescription: "Cloudflare ist als der Standardserver festgelegt, dieser kann jederzeit geändern werden.", | ||||
|     resolverserverDescription: "Cloudflare ist als der Standardserver festgelegt. Dieser kann jederzeit geändert werden.", | ||||
|     "Resolver Server": "Auflösungsserver", | ||||
|     rrtypeDescription: "Wähle den RR-Typ aus, welchen du überwachen möchtest.", | ||||
|     "Last Result": "Letztes Ergebnis", | ||||
| @@ -110,8 +110,8 @@ export default { | ||||
|     Heartbeats: "Statistiken", | ||||
|     confirmClearStatisticsMsg: "Bist du dir sicher, dass du ALLE Statistiken löschen möchtest?", | ||||
|     "Create your admin account": "Erstelle dein Admin-Konto", | ||||
|     "Repeat Password": "Wiederhole das Passwort", | ||||
|     "Resource Record Type": "Resource Record Type", | ||||
|     "Repeat Password": "Passwort erneut eingeben", | ||||
|     "Resource Record Type": "Ressourcen Record Typ", | ||||
|     Export: "Export", | ||||
|     Import: "Import", | ||||
|     respTime: "Antw.-Zeit (ms)", | ||||
| @@ -148,7 +148,7 @@ export default { | ||||
|     Token: "Token", | ||||
|     "Show URI": "URI anzeigen", | ||||
|     Tags: "Tags", | ||||
|     "Add New below or Select...": "Bestehenden Tag auswählen oder neuen hinzufügen...", | ||||
|     "Add New below or Select...": "Einen bestehenden Tag auswählen oder neuen hinzufügen...", | ||||
|     "Tag with this name already exist.": "Ein Tag mit diesem Namen existiert bereits.", | ||||
|     "Tag with this value already exist.": "Ein Tag mit diesem Wert existiert bereits.", | ||||
|     color: "Farbe", | ||||
| @@ -162,8 +162,8 @@ export default { | ||||
|     Purple: "Lila", | ||||
|     Pink: "Pink", | ||||
|     "Search...": "Suchen...", | ||||
|     "Heartbeat Retry Interval": "Heartbeat-Wiederholungsintervall", | ||||
|     retryCheckEverySecond: "Versuche alle {0} Sekunden", | ||||
|     "Heartbeat Retry Interval": "Überprüfungsintervall", | ||||
|     retryCheckEverySecond: "Alle {0} Sekunden neu versuchen", | ||||
|     "Import Backup": "Backup importieren", | ||||
|     "Export Backup": "Backup exportieren", | ||||
|     "Avg. Ping": "Durchschn. Ping", | ||||
| @@ -194,6 +194,7 @@ export default { | ||||
|     promosms: "PromoSMS", | ||||
|     lunasea: "LunaSea", | ||||
|     apprise: "Apprise (Unterstützung für 50+ Benachrichtigungsdienste)", | ||||
|     GoogleChat: "Google Chat (nur Google Workspace)", | ||||
|     pushbullet: "Pushbullet", | ||||
|     line: "Line Messenger", | ||||
|     mattermost: "Mattermost", | ||||
| @@ -201,7 +202,7 @@ export default { | ||||
|     "Push URL": "Push URL", | ||||
|     needPushEvery: "Du solltest diese URL alle {0} Sekunden aufrufen", | ||||
|     pushOptionalParams: "Optionale Parameter: {0}", | ||||
|     defaultNotificationName: "Meine {notification} Alarm ({number})", | ||||
|     defaultNotificationName: "Mein {notification} Alarm ({number})", | ||||
|     here: "hier", | ||||
|     Required: "Erforderlich", | ||||
|     "Bot Token": "Bot Token", | ||||
| @@ -213,23 +214,23 @@ export default { | ||||
|     chatIDNotFound: "Chat-ID wurde nicht gefunden: bitte sende zuerst eine Nachricht an diesen Bot", | ||||
|     "Post URL": "Post URL", | ||||
|     "Content Type": "Content Type", | ||||
|     webhookJsonDesc: "{0} ist gut für alle modernen HTTP-Server sowie Express.js", | ||||
|     webhookFormDataDesc: "{multipart} ist gut für PHP. Die JSON muss mit {decodeFunction} geparst werden", | ||||
|     webhookJsonDesc: "{0} ist gut für alle modernen HTTP-Server, wie z.B. Express.js, geeignet", | ||||
|     webhookFormDataDesc: "{multipart} ist gut für PHP. Das JSON muss mit {decodeFunction} verarbeitet werden", | ||||
|     secureOptionNone: "Keine / STARTTLS (25, 587)", | ||||
|     secureOptionTLS: "TLS (465)", | ||||
|     "Ignore TLS Error": "TLS-Fehler ignorieren", | ||||
|     "From Email": "Von Email", | ||||
|     "From Email": "Absender E-Mail", | ||||
|     emailCustomSubject: "Benutzerdefinierter Betreff", | ||||
|     "To Email": "Zu Email", | ||||
|     "To Email": "Empfänger E-Mail", | ||||
|     smtpCC: "CC", | ||||
|     smtpBCC: "BCC", | ||||
|     "Discord Webhook URL": "Discord Webhook URL", | ||||
|     wayToGetDiscordURL: "Du kannst diesen erhalten, indem du zu den Servereinstellungen gehst -> Integrationen -> Neuer Webhook", | ||||
|     wayToGetDiscordURL: "Du kannst diese erhalten, indem du zu den Servereinstellungen gehst -> Integrationen -> Neuer Webhook", | ||||
|     "Bot Display Name": "Bot-Anzeigename", | ||||
|     "Prefix Custom Message": "Benutzerdefinierter Nachrichten Präfix", | ||||
|     "Hello @everyone is...": "Hallo {'@'}everyone ist...", | ||||
|     "Webhook URL": "Webhook URL", | ||||
|     wayToGetTeamsURL: "Hier erfährst du, wie eine Webhook-URL erstellt werden kann {0}.", | ||||
|     wayToGetTeamsURL: "Wie eine Webhook-URL erstellt werden kann, erfährst du {0}.", | ||||
|     Number: "Nummer", | ||||
|     Recipients: "Empfänger", | ||||
|     needSignalAPI: "Es wird ein Signal Client mit REST-API benötigt.", | ||||
| @@ -242,22 +243,22 @@ export default { | ||||
|     "Channel Name": "Kanalname", | ||||
|     "Uptime Kuma URL": "Uptime Kuma URL", | ||||
|     aboutWebhooks: "Weitere Informationen zu Webhooks auf: {0}", | ||||
|     aboutChannelName: "Gebe den Kanalnamen ein auf {0} Feld Kanalname, wenn du den Webhook-Kanal umgehen möchtest. Ex: #other-channel", | ||||
|     aboutKumaURL: "Wenn das Feld für die Uptime Kuma URL leer gelassen wird, wird es standardmäßig die GitHub Projekt Seite verwenden.", | ||||
|     aboutChannelName: "Gebe den Kanalnamen ein in {0} Feld Kanalname, falls du den Webhook-Kanal umgehen möchtest. Ex: #other-channel", | ||||
|     aboutKumaURL: "Wenn das Feld für die Uptime Kuma URL leer gelassen wird, wird standardmäßig die GitHub Projekt Seite verwendet.", | ||||
|     emojiCheatSheet: "Emoji Cheat Sheet: {0}", | ||||
|     "User Key": "Benutzerschlüssel", | ||||
|     Device: "Gerät", | ||||
|     "Message Title": "Nachrichtentitel", | ||||
|     "Notification Sound": "Benachrichtigungston", | ||||
|     "More info on:": "Mehr Infos auf: {0}", | ||||
|     pushoverDesc1: "Notfallpriorität (2) hat Standardmäßig 30 Sekunden Auszeit, zwischen den Versuchen und läuft nach 1 Stunde ab.", | ||||
|     pushoverDesc1: "Notfallpriorität (2) hat standardmäßig 30 Sekunden Auszeit zwischen den Versuchen und läuft nach 1 Stunde ab.", | ||||
|     pushoverDesc2: "Fülle das Geräte Feld aus, wenn du Benachrichtigungen an verschiedene Geräte senden möchtest.", | ||||
|     "SMS Type": "SMS Typ", | ||||
|     octopushTypePremium: "Premium (Schnell - zur Benachrichtigung empfohlen)", | ||||
|     octopushTypeLowCost: "Kostengünstig (Langsam - manchmal vom Betreiber gesperrt)", | ||||
|     checkPrice: "Prüfe {0} Preise:", | ||||
|     octopushLegacyHint: "Verwendest du die Legacy-Version von Octopush (2011-2020) oder die neue Version?", | ||||
|     "Check octopush prices": "Überprüfe die Oktopush Preise {0}.", | ||||
|     "Check octopush prices": "Vergleiche die Oktopush Preise {0}.", | ||||
|     octopushPhoneNumber: "Telefonnummer (Internationales Format, z.B : +49612345678) ", | ||||
|     octopushSMSSender: "Name des SMS-Absenders : 3-11 alphanumerische Zeichen und Leerzeichen (a-zA-Z0-9)", | ||||
|     "LunaSea Device ID": "LunaSea Geräte ID", | ||||
| @@ -278,24 +279,24 @@ export default { | ||||
|     wayToGetLineChannelToken: "Rufe zuerst {0} auf, erstelle dann einen Provider und Channel (Messaging API). Als nächstes kannst du den Channel access token und die User ID aus den oben genannten Menüpunkten abrufen.", | ||||
|     "Icon URL": "Icon URL", | ||||
|     aboutIconURL: "Du kannst einen Link zu einem Bild in 'Icon URL' übergeben um das Standardprofilbild zu überschreiben. Wird nicht verwendet, wenn ein Icon Emoji gesetzt ist.", | ||||
|     aboutMattermostChannelName: "Du kannst den Standardkanal, auf dem der Webhook postet überschreiben, indem der Kanalnamen in das Feld 'Channel Name' eingeben wird. Dies muss in den Mattermost Webhook-Einstellungen aktiviert werden. Ex: #other-channel", | ||||
|     aboutMattermostChannelName: "Du kannst den Standardkanal, auf dem der Webhook gesendet wird überschreiben, indem der Kanalnamen in das Feld 'Channel Name' eingeben wird. Dies muss in den Mattermost Webhook-Einstellungen aktiviert werden. Ex: #other-channel", | ||||
|     matrix: "Matrix", | ||||
|     promosmsTypeEco: "SMS ECO - billig, aber langsam und oft überladen. Nur auf polnische Empfänger beschränkt.", | ||||
|     promosmsTypeFlash: "SMS FLASH - Die Nachricht wird automatisch auf dem Empfängergerät angezeigt. Nur auf polnische Empfänger beschränkt.", | ||||
|     promosmsTypeEco: "SMS ECO - billig, aber langsam und oft überladen. Auf polnische Empfänger beschränkt.", | ||||
|     promosmsTypeFlash: "SMS FLASH - Die Nachricht wird automatisch auf dem Empfängergerät angezeigt. Auf polnische Empfänger beschränkt.", | ||||
|     promosmsTypeFull: "SMS FULL - Premium Stufe von SMS, es kann der Absendernamen verwendet werden (Der Name musst zuerst registriert werden). Zuverlässig für Warnungen.", | ||||
|     promosmsTypeSpeed: "SMS SPEED - Höchste Priorität im System. Sehr schnell und zuverlässig, aber teuer (Ungefähr das doppelte von SMS FULL).", | ||||
|     promosmsPhoneNumber: "Phone number (Für polnische Empfänger können die Vorwahlen übersprungen werden)", | ||||
|     promosmsPhoneNumber: "Telefonnummer (für polnische Empfänger können die Vorwahlen übersprungen werden)", | ||||
|     promosmsSMSSender: "Name des SMS-Absenders : vorregistrierter Name oder einer der Standardwerte: InfoSMS, SMS Info, MaxSMS, INFO, SMS", | ||||
|     "Feishu WebHookUrl": "Feishu Webhook URL", | ||||
|     matrixHomeserverURL: "Heimserver URL (mit http(s):// und optionalen Ports)", | ||||
|     "Internal Room Id": "Interne Raum-ID", | ||||
|     matrixDesc1: "Die interne Raum-ID findest du im erweiterten Bereich der Raumeinstellungen im Matrix-Client. Es sollte es aussehen wie z.B. !QMdRCpUIfLwsfjxye6:home.server.", | ||||
|     matrixDesc2: "Es wird dringend empfohlen, dass ein neuen Benutzer erstellt wird und nicht den Zugriffstoken deines eigenen Matrix-Benutzers verwendest. Anderfalls ermöglicht es vollen Zugriff auf dein Konto und alle Räume, denen du beigetreten bist. Erstelle stattdessen einen neuen Benutzer und lade ihn nur in den Raum ein, in dem du die Benachrichtigung erhalten möchtest. Du kannst den Zugriffstoken erhalten, indem du folgendes ausführst {0}", | ||||
|     matrixDesc1: "Die interne Raum-ID findest du im erweiterten Bereich der Raumeinstellungen im Matrix-Client. Es sollte aussehen wie z.B. !QMdRCpUIfLwsfjxye6:home.server.", | ||||
|     matrixDesc2: "Es wird dringend empfohlen einen neuen Benutzer anzulegen und nicht den Zugriffstoken deines eigenen Matrix-Benutzers zu verwenden. Anderenfalls ermöglicht es vollen Zugriff auf dein Konto und alle Räume, denen du beigetreten bist. Erstelle stattdessen einen neuen Benutzer und lade ihn nur in den Raum ein, in dem du die Benachrichtigung erhalten möchtest. Du kannst den Zugriffstoken erhalten, indem du Folgendes ausführst {0}", | ||||
|     Method: "Method", | ||||
|     Body: "Body", | ||||
|     Headers: "Headers", | ||||
|     PushUrl: "Push URL", | ||||
|     HeadersInvalidFormat: "Die Header ist kein gültiges JSON: ", | ||||
|     HeadersInvalidFormat: "Der Header ist kein gültiges JSON: ", | ||||
|     BodyInvalidFormat: "Der Body ist kein gültiges JSON: ", | ||||
|     "Monitor History": "Monitor Verlauf", | ||||
|     clearDataOlderThan: "Bewahre die Monitor-Verlaufsdaten für {0} Tage auf.", | ||||
| @@ -304,4 +305,60 @@ export default { | ||||
|     "One record": "Ein Eintrag", | ||||
|     steamApiKeyDescription: "Um einen Steam Game Server zu überwachen, wird ein Steam Web-API-Schlüssel benötigt. Dieser kann hier registriert werden: ", | ||||
|     "Current User": "Aktueller Benutzer", | ||||
|     recent: "Letzte", | ||||
|     Done: "Fertig", | ||||
|     Info: "Info", | ||||
|     Security: "Sicherheit", | ||||
|     "Steam API Key": "Steam API Key", | ||||
|     "Shrink Database": "Datenbank verkleinern", | ||||
|     "Pick a RR-Type...": "Wähle ein RR-Typ aus...", | ||||
|     "Pick Accepted Status Codes...": "Wähle akzeptierte Statuscodes aus...", | ||||
|     Default: "Standard", | ||||
|     "HTTP Options": "HTTP Optionen", | ||||
|     "Create Incident": "Vorfall erstellen", | ||||
|     Title: "Titel", | ||||
|     Content: "Inhalt", | ||||
|     Style: "Stil", | ||||
|     info: "info", | ||||
|     warning: "warnung", | ||||
|     danger: "gefahr", | ||||
|     primary: "primär", | ||||
|     light: "hell", | ||||
|     dark: "dunkel", | ||||
|     Post: "Eintrag", | ||||
|     "Please input title and content": "Bitte Titel und Inhalt eingeben", | ||||
|     Created: "Erstellt", | ||||
|     "Last Updated": "Zuletzt aktualisiert", | ||||
|     Unpin: "Loslösen", | ||||
|     "Switch to Light Theme": "Zu hellem Thema wechseln", | ||||
|     "Switch to Dark Theme": "Zum dunklen Thema wechseln", | ||||
|     "Show Tags": "Tags anzeigen", | ||||
|     "Hide Tags": "Tags ausblenden", | ||||
|     Description: "Beschreibung", | ||||
|     "No monitors available.": "Keine Monitore verfügbar.", | ||||
|     "Add one": "Füge eins hinzu", | ||||
|     "No Monitors": "Keine Monitore", | ||||
|     "Untitled Group": "Gruppe ohne Titel", | ||||
|     Services: "Dienste", | ||||
|     Discard: "Verwerfen", | ||||
|     Cancel: "Abbrechen", | ||||
|     "Powered by": "Powered by", | ||||
|     shrinkDatabaseDescription: "Löse VACUUM für die SQLite Datenbank aus. Wenn die Datenbank nach 1.10.0 erstellt wurde, ist AUTO_VACUUM bereits aktiviert und diese Aktion ist nicht erforderlich.", | ||||
|     serwersms: "SerwerSMS.pl", | ||||
|     serwersmsAPIUser: "API Benutzername (inkl. webapi_ prefix)", | ||||
|     serwersmsAPIPassword: "API Passwort", | ||||
|     serwersmsPhoneNumber: "Telefonnummer", | ||||
|     serwersmsSenderName: "Name des SMS-Absenders (über Kundenportal registriert)", | ||||
|     "stackfield": "Stackfield", | ||||
|     clicksendsms: "ClickSend SMS", | ||||
|     apiCredentials: "API Zugangsdaten", | ||||
|     smtpDkimSettings: "DKIM Einstellungen", | ||||
|     smtpDkimDesc: "Details zur Konfiguration sind in der Nodemailer DKIM {0} zu finden.", | ||||
|     documentation: "Dokumentation", | ||||
|     smtpDkimDomain: "Domain Name", | ||||
|     smtpDkimKeySelector: "Schlüssel Auswahl", | ||||
|     smtpDkimPrivateKey: "Privater Schlüssel", | ||||
|     smtpDkimHashAlgo: "Hash-Algorithmus (Optional)", | ||||
|     smtpDkimheaderFieldNames: "Zu validierende Header-Schlüssel (optional)", | ||||
|     smtpDkimskipFields: "Zu ignorierende Header Schlüssel (optional)", | ||||
| }; | ||||
|   | ||||
| @@ -13,7 +13,7 @@ export default { | ||||
|     pauseDashboardHome: "Pause", | ||||
|     deleteMonitorMsg: "Are you sure want to delete this monitor?", | ||||
|     deleteNotificationMsg: "Are you sure want to delete this notification for all monitors?", | ||||
|     resoverserverDescription: "Cloudflare is the default server. You can change the resolver server anytime.", | ||||
|     resolverserverDescription: "Cloudflare is the default server. You can change the resolver server anytime.", | ||||
|     rrtypeDescription: "Select the RR type you want to monitor", | ||||
|     pauseMonitorMsg: "Are you sure want to pause?", | ||||
|     enableDefaultNotificationDescription: "This notification will be enabled by default for new monitors. You can still disable the notification separately for each monitor.", | ||||
| @@ -243,6 +243,7 @@ export default { | ||||
|     clicksendsms: "ClickSend SMS", | ||||
|     lunasea: "LunaSea", | ||||
|     apprise: "Apprise (Support 50+ Notification services)", | ||||
|     GoogleChat: "Google Chat (Google Workspace only)", | ||||
|     pushbullet: "Pushbullet", | ||||
|     line: "Line Messenger", | ||||
|     mattermost: "Mattermost", | ||||
| @@ -339,7 +340,6 @@ export default { | ||||
|     "No monitors available.": "No monitors available.", | ||||
|     "Add one": "Add one", | ||||
|     "No Monitors": "No Monitors", | ||||
|     "Add one": "Add one", | ||||
|     "Untitled Group": "Untitled Group", | ||||
|     Services: "Services", | ||||
|     Discard: "Discard", | ||||
| @@ -352,4 +352,13 @@ export default { | ||||
|     serwersmsPhoneNumber: "Phone number", | ||||
|     serwersmsSenderName: "SMS Sender Name (registered via customer portal)", | ||||
|     "stackfield": "Stackfield", | ||||
|     smtpDkimSettings: "DKIM Settings", | ||||
|     smtpDkimDesc: "Please refer to the Nodemailer DKIM {0} for usage.", | ||||
|     documentation: "documentation", | ||||
|     smtpDkimDomain: "Domain Name", | ||||
|     smtpDkimKeySelector: "Key Selector", | ||||
|     smtpDkimPrivateKey: "Private Key", | ||||
|     smtpDkimHashAlgo: "Hash Algorithm (Optional)", | ||||
|     smtpDkimheaderFieldNames: "Header Keys to sign (Optional)", | ||||
|     smtpDkimskipFields: "Header Keys not to sign (Optional)", | ||||
| }; | ||||
|   | ||||
| @@ -12,7 +12,7 @@ export default { | ||||
|     pauseDashboardHome: "Pausado", | ||||
|     deleteMonitorMsg: "¿Seguro que quieres eliminar este monitor?", | ||||
|     deleteNotificationMsg: "¿Seguro que quieres eliminar esta notificación para todos los monitores?", | ||||
|     resoverserverDescription: "Cloudflare es el servidor por defecto, puedes cambiar el servidor de resolución en cualquier momento.", | ||||
|     resolverserverDescription: "Cloudflare es el servidor por defecto, puedes cambiar el servidor de resolución en cualquier momento.", | ||||
|     rrtypeDescription: "Selecciona el tipo de registro que quieres monitorizar", | ||||
|     pauseMonitorMsg: "¿Seguro que quieres pausar?", | ||||
|     Settings: "Ajustes", | ||||
|   | ||||
| @@ -12,7 +12,7 @@ export default { | ||||
|     pauseDashboardHome: "Seisatud", | ||||
|     deleteMonitorMsg: "Kas soovid eemaldada seire?", | ||||
|     deleteNotificationMsg: "Kas soovid eemaldada selle teavitusteenuse kõikidelt seiretelt?", | ||||
|     resoverserverDescription: "Cloudflare on vaikimisi pöördserver.", | ||||
|     resolverserverDescription: "Cloudflare on vaikimisi pöördserver.", | ||||
|     rrtypeDescription: "Vali kirje tüüp, mida soovid jälgida.", | ||||
|     pauseMonitorMsg: "Kas soovid peatada seire?", | ||||
|     Settings: "Seaded", | ||||
|   | ||||
| @@ -13,7 +13,7 @@ export default { | ||||
|     pauseDashboardHome: "متوقف شده", | ||||
|     deleteMonitorMsg: "آیا از حذف این مانیتور مطمئن هستید؟", | ||||
|     deleteNotificationMsg: "آیا مطمئن هستید که میخواهید این سرویس اطلاعرسانی را برای تمامی مانیتورها حذف کنید؟", | ||||
|     resoverserverDescription: "سرویس CloudFlare به عنوان سرور پیشفرض استفاده میشود، شما میتوانید آنرا به هر سرور دیگری بعدا تغییر دهید.", | ||||
|     resolverserverDescription: "سرویس CloudFlare به عنوان سرور پیشفرض استفاده میشود، شما میتوانید آنرا به هر سرور دیگری بعدا تغییر دهید.", | ||||
|     rrtypeDescription: "لطفا نوع Resource Record را انتخاب کنید.", | ||||
|     pauseMonitorMsg: "آیا مطمئن هستید که میخواهید این مانیتور را متوقف کنید ؟", | ||||
|     enableDefaultNotificationDescription: "برای هر مانیتور جدید، این سرویس اطلاعرسانی به صورت پیشفرض فعال خواهد شد. البته که شما میتوانید به صورت دستی آنرا برای هر مانیتور به صورت جداگانه غیر فعال کنید.", | ||||
|   | ||||
| @@ -13,7 +13,7 @@ export default { | ||||
|     pauseDashboardHome: "En pause", | ||||
|     deleteMonitorMsg: "Êtes-vous sûr de vouloir supprimer cette sonde ?", | ||||
|     deleteNotificationMsg: "Êtes-vous sûr de vouloir supprimer ce type de notifications ? Une fois désactivée, les services qui l'utilisent ne pourront plus envoyer de notifications.", | ||||
|     resoverserverDescription: "Le DNS de Cloudflare est utilisé par défaut, mais vous pouvez le changer si vous le souhaitez.", | ||||
|     resolverserverDescription: "Le DNS de Cloudflare est utilisé par défaut, mais vous pouvez le changer si vous le souhaitez.", | ||||
|     rrtypeDescription: "Veuillez sélectionner un type d'enregistrement DNS", | ||||
|     pauseMonitorMsg: "Êtes-vous sûr de vouloir mettre en pause cette sonde ?", | ||||
|     enableDefaultNotificationDescription: "Pour chaque nouvelle sonde, cette notification sera activée par défaut. Vous pouvez toujours désactiver la notification séparément pour chaque sonde.", | ||||
| @@ -129,7 +129,7 @@ export default { | ||||
|     Create: "Créer", | ||||
|     "Clear Data": "Effacer les données", | ||||
|     Events: "Evénements", | ||||
|     Heartbeats: "Vérfications", | ||||
|     Heartbeats: "Vérifications", | ||||
|     "Auto Get": "Récuperer automatiquement", | ||||
|     backupDescription: "Vous pouvez sauvegarder toutes les sondes et toutes les notifications dans un fichier JSON.", | ||||
|     backupDescription2: "PS : Les données relatives à l'historique et aux événements ne sont pas incluses.", | ||||
| @@ -207,7 +207,7 @@ export default { | ||||
|     "Discord Webhook URL": "Discord Webhook URL", | ||||
|     wayToGetDiscordURL: "Vous pouvez l'obtenir en allant dans 'Paramètres du Serveur' -> 'Intégrations' -> 'Créer un Webhook'", | ||||
|     "Bot Display Name": "Nom du bot (affiché)", | ||||
|     "Prefix Custom Message": "Prefix Custom Message", | ||||
|     "Prefix Custom Message": "Prefixe du message personnalisé", | ||||
|     "Hello @everyone is...": "Bonjour {'@'}everyone il...", | ||||
|     teams: "Microsoft Teams", | ||||
|     "Webhook URL": "Webhook URL", | ||||
| @@ -229,7 +229,7 @@ export default { | ||||
|     aboutWebhooks: "Plus d'informations sur les Webhooks ici : {0}", | ||||
|     aboutChannelName: "Mettez le nom du salon dans {0} dans 'Channel Name' si vous voulez bypass le salon Webhook. Ex : #autre-salon", | ||||
|     aboutKumaURL: "Si vous laissez l'URL d'Uptime Kuma vierge, elle redirigera vers la page du projet GitHub.", | ||||
|     emojiCheatSheet: "Emoji cheat sheet : {0}", | ||||
|     emojiCheatSheet: "Aide emoji : {0}", | ||||
|     "rocket.chat": "Rocket.chat", | ||||
|     pushover: "Pushover", | ||||
|     pushy: "Pushy", | ||||
| @@ -262,9 +262,9 @@ export default { | ||||
|     appriseInstalled: "Apprise est installé.", | ||||
|     appriseNotInstalled: "Apprise n'est pas installé. {0}", | ||||
|     "Access Token": "Access Token", | ||||
|     "Channel access token": "Channel access token", | ||||
|     "Line Developers Console": "Line Developers Console", | ||||
|     lineDevConsoleTo: "Line Developers Console - {0}", | ||||
|     "Channel access token": "Token d'accès au canal", | ||||
|     "Line Developers Console": "Ligne console de développeurs", | ||||
|     lineDevConsoleTo: "Ligne console de développeurs - {0}", | ||||
|     "Basic Settings": "Paramètres de base", | ||||
|     "User ID": "Identifiant utilisateur", | ||||
|     "Messaging API": "Messaging API", | ||||
|   | ||||
| @@ -12,7 +12,7 @@ export default { | ||||
|     keywordDescription: "Ključna riječ za pretragu, u obliku običnog HTML-a ili u JSON formatu. Pretraga je osjetljiva na velika i mala slova.", | ||||
|     deleteMonitorMsg: "Jeste li sigurni da želite izbrisati monitor?", | ||||
|     deleteNotificationMsg: "Jeste li sigurni da želite izbrisati ovu obavijest za sve monitore?", | ||||
|     resoverserverDescription: "Cloudflare je zadani DNS poslužitelj. Možete to promijeniti u bilo kojem trenutku.", | ||||
|     resolverserverDescription: "Cloudflare je zadani DNS poslužitelj. Možete to promijeniti u bilo kojem trenutku.", | ||||
|     rrtypeDescription: "Odaberite vrstu DNS zapisa o resursu kojeg želite pratiti", | ||||
|     pauseMonitorMsg: "Jeste li sigurni da želite pauzirati?", | ||||
|     enableDefaultNotificationDescription: "Ova će obavijesti biti omogućena za sve nove monitore. Možete ju ručno onemogućiti za pojedini monitor.", | ||||
| @@ -338,9 +338,8 @@ export default { | ||||
|     "Hide Tags": "Sakrij oznake", | ||||
|     Description: "Opis", | ||||
|     "No monitors available.": "Nema dostupnih monitora.", | ||||
|     "Add one": "Add one", | ||||
|     "No Monitors": "Bez monitora", | ||||
|     "Add one": "Stvori jednog", | ||||
|     "No Monitors": "Bez monitora", | ||||
|     "Untitled Group": "Bezimena grupa", | ||||
|     Services: "Usluge", | ||||
|     Discard: "Odbaci", | ||||
|   | ||||
| @@ -13,7 +13,7 @@ export default { | ||||
|     pauseDashboardHome: "Szünetel", | ||||
|     deleteMonitorMsg: "Biztos, hogy törölni akarja ezt a figyelőt?", | ||||
|     deleteNotificationMsg: "Biztos, hogy törölni akarja ezt az értesítést az összes figyelőnél?", | ||||
|     resoverserverDescription: "A Cloudflare az alapértelmezett szerver, bármikor meg tudja változtatni a resolver server-t.", | ||||
|     resolverserverDescription: "A Cloudflare az alapértelmezett szerver, bármikor meg tudja változtatni a resolver server-t.", | ||||
|     rrtypeDescription: "Válassza ki az RR-típust a figyelőhöz", | ||||
|     pauseMonitorMsg: "Biztos, hogy szüneteltetni akarja?", | ||||
|     enableDefaultNotificationDescription: "Minden új figyelőhöz ez az értesítés engedélyezett lesz alapértelmezetten. Kikapcsolhatja az értesítést külön minden figyelőnél.", | ||||
| @@ -350,4 +350,15 @@ export default { | ||||
|     serwersmsAPIPassword: "API jelszó", | ||||
|     serwersmsPhoneNumber: "Telefonszám", | ||||
|     serwersmsSenderName: "SMS feladó neve (regisztrált név az oldalon)", | ||||
|     GoogleChat: "Google Chat (csak Google Workspace)", | ||||
|     stackfield: "Stackfield", | ||||
|     smtpDkimSettings: "DKIM beállítások", | ||||
|     smtpDkimDesc: "Nézze meg a Nodemailer DKIM {0} használati szabályokat.", | ||||
|     documentation: "dokumentáció", | ||||
|     smtpDkimDomain: "Domain név", | ||||
|     smtpDkimKeySelector: "Kulcs választó", | ||||
|     smtpDkimPrivateKey: "Privát kulcs", | ||||
|     smtpDkimHashAlgo: "Hash algoritmus (nem kötelező)", | ||||
|     smtpDkimheaderFieldNames: "Fejléc kulcsok a bejelentkezéshez (nem kötelező)", | ||||
|     smtpDkimskipFields: "Fejléc kulcsok egyéb esetben (nem kötelező)", | ||||
| }; | ||||
|   | ||||
| @@ -7,13 +7,13 @@ export default { | ||||
|     upsideDownModeDescription: "Balikkan statusnya. Jika layanan dapat dijangkau, TIDAK AKTIF.", | ||||
|     maxRedirectDescription: "Jumlah maksimum pengalihan untuk diikuti. Setel ke 0 untuk menonaktifkan pengalihan.", | ||||
|     acceptedStatusCodesDescription: "Pilih kode status yang dianggap sebagai tanggapan yang berhasil.", | ||||
|     passwordNotMatchMsg: "Sandi kedua tidak cocok.", | ||||
|     passwordNotMatchMsg: "Kata sandi kedua tidak cocok.", | ||||
|     notificationDescription: "Harap atur notifikasi ke monitor agar berfungsi.", | ||||
|     keywordDescription: "Cari kata kunci dalam code html atau JSON huruf besar-kecil berpengaruh", | ||||
|     pauseDashboardHome: "Jeda", | ||||
|     deleteMonitorMsg: "Apakah Anda mau menghapus monitor ini?", | ||||
|     deleteNotificationMsg: "Apakah Anda mau menghapus notifikasi ini untuk semua monitor?", | ||||
|     resoverserverDescription: "Cloudflare adalah server bawaan, Anda dapat mengubah server resolver kapan saja.", | ||||
|     deleteNotificationMsg: "Apakah Anda mau menghapus notifikasi untuk semua monitor?", | ||||
|     resolverserverDescription: "Cloudflare adalah server bawaan, Anda dapat mengubah server resolver kapan saja.", | ||||
|     rrtypeDescription: "Pilih RR-Type yang mau Anda monitor", | ||||
|     pauseMonitorMsg: "Apakah Anda yakin mau menjeda?", | ||||
|     enableDefaultNotificationDescription: "Untuk setiap monitor baru, notifikasi ini akan diaktifkan secara bawaan. Anda masih dapat menonaktifkan notifikasi secara terpisah untuk setiap monitor.", | ||||
| @@ -23,9 +23,9 @@ export default { | ||||
|     importHandleDescription: "Pilih 'Lewati yang ada' jika Anda ingin melewati setiap monitor atau notifikasi dengan nama yang sama. 'Timpa' akan menghapus setiap monitor dan notifikasi yang ada.", | ||||
|     confirmImportMsg: "Apakah Anda yakin untuk mengimpor cadangan? Pastikan Anda telah memilih opsi impor yang tepat.", | ||||
|     twoFAVerifyLabel: "Silakan ketik token Anda untuk memverifikasi bahwa 2FA berfungsi", | ||||
|     tokenValidSettingsMsg: "Tokennya benar! Anda sekarang dapat menyimpan pengaturan 2FA.", | ||||
|     confirmEnableTwoFAMsg: "Apakah Anda yakin ingin mengaktifkan 2FA?", | ||||
|     confirmDisableTwoFAMsg: "Apakah Anda yakin ingin menonaktifkan 2FA?", | ||||
|     tokenValidSettingsMsg: "Token benar! Anda sekarang dapat menyimpan pengaturan 2FA.", | ||||
|     confirmEnableTwoFAMsg: "Apakah anda yakin ingin mengaktifkan 2FA?", | ||||
|     confirmDisableTwoFAMsg: "Apakah anda yakin ingin menonaktifkan 2FA?", | ||||
|     Settings: "Pengaturan", | ||||
|     Dashboard: "Dasbor", | ||||
|     "New Update": "Pembaruan Baru", | ||||
| @@ -276,7 +276,7 @@ export default { | ||||
|     promosmsTypeEco: "SMS ECO - murah tapi lambat dan sering kelebihan beban. Terbatas hanya untuk penerima Polandia.", | ||||
|     promosmsTypeFlash: "SMS FLASH - Pesan akan otomatis muncul di perangkat penerima. Terbatas hanya untuk penerima Polandia.", | ||||
|     promosmsTypeFull: "SMS FULL - SMS tingkat premium, Anda dapat menggunakan Nama Pengirim Anda (Anda harus mendaftarkan nama terlebih dahulu). Dapat diAndalkan untuk peringatan.", | ||||
|     promosmsTypeSpeed: "SMS SPEED - Prioritas tertinggi dalam sistem. Sangat cepat dan dapat diAndalkan tetapi mahal (sekitar dua kali lipat dari harga SMS FULL).", | ||||
|     promosmsTypeSpeed: "SMS SPEED - Prioritas tertinggi dalam sistem. Sangat cepat dan dapat diandalkan tetapi mahal (sekitar dua kali lipat dari harga SMS FULL).", | ||||
|     promosmsPhoneNumber: "Nomor telepon (untuk penerima Polandia Anda dapat melewati kode area)", | ||||
|     promosmsSMSSender: "Nama Pengirim SMS : Nama pra-registrasi atau salah satu bawaan: InfoSMS, Info SMS, MaxSMS, INFO, SMS", | ||||
|     "Feishu WebHookUrl": "Feishu WebHookUrl", | ||||
|   | ||||
| @@ -2,49 +2,49 @@ export default { | ||||
|     languageName: "Italiano (Italian)", | ||||
|     checkEverySecond: "controlla ogni {0} secondi", | ||||
|     retryCheckEverySecond: "Riprova ogni {0} secondi.", | ||||
|     retriesDescription: "Tentativi da fare prima che il servizio venga marcato come \"giù\" e che una notifica venga inviata.", | ||||
|     ignoreTLSError: "Ignora gli errori TLS/SSL per i siti in HTTPS.", | ||||
|     upsideDownModeDescription: "Capovolgi lo stato. Se il servizio è raggiungibile viene marcato come \"GIÙ\".", | ||||
|     maxRedirectDescription: "Numero massimo di redirezionamenti consentito. Per disabilitare impostare \"0\".", | ||||
|     acceptedStatusCodesDescription: "Inserire i codici di stato considerati come risposte corrette.", | ||||
|     retriesDescription: "Tentativi prima che il servizio venga marcato come \"DOWN\" e che una notifica venga inviata.", | ||||
|     ignoreTLSError: "Ignora gli errori TLS/SSL per i siti HTTPS.", | ||||
|     upsideDownModeDescription: "Se il servizio risulta raggiungibile viene marcato come \"DOWN\".", | ||||
|     maxRedirectDescription: "Numero massimo di redirezionamenti consentito. Per disabilitare, impostare \"0\".", | ||||
|     acceptedStatusCodesDescription: "Elenco di codici di stato HTTP che sono considerati validi.", | ||||
|     passwordNotMatchMsg: "La password non coincide.", | ||||
|     notificationDescription: "Assegnare la notifica a uno o più elementi monitorati per metterla in funzione.", | ||||
|     notificationDescription: "Assegnare la notifica a uno o più oggetti monitorati per metterla in funzione.", | ||||
|     keywordDescription: "Cerca la parola chiave nella risposta in html o JSON e fai distinzione tra maiuscole e minuscole", | ||||
|     pauseDashboardHome: "In Pausa", | ||||
|     deleteMonitorMsg: "Si è certi di voler eliminare questo monitoraggio?", | ||||
|     deleteMonitorMsg: "Si è certi di voler eliminare questo oggetto monitorato?", | ||||
|     deleteNotificationMsg: "Si è certi di voler eliminare questa notifica per tutti gli oggetti monitorati?", | ||||
|     resoverserverDescription: "Cloudflare è il server predefinito, è possibile cambiare il server DNS.", | ||||
|     resolverserverDescription: "Cloudflare è il server predefinito, è possibile cambiare il server DNS.", | ||||
|     rrtypeDescription: "Scegliere il tipo di RR che si vuole monitorare", | ||||
|     pauseMonitorMsg: "Si è certi di voler mettere in pausa?", | ||||
|     enableDefaultNotificationDescription: "Per ogni nuovo monitoraggio questa notifica sarà abilitata di default. È comunque possibile disabilitare la notifica separatamente per ogni monitoraggio.", | ||||
|     enableDefaultNotificationDescription: "Per ogni nuovo monitor questa notifica sarà abilitata di default. È comunque possibile disabilitare la notifica singolarmente.", | ||||
|     clearEventsMsg: "Si è certi di voler eliminare tutti gli eventi per questo servizio?", | ||||
|     clearHeartbeatsMsg: "Si è certi di voler eliminare tutti gli intervalli di controllo per questo servizio?", | ||||
|     confirmClearStatisticsMsg: "Si è certi di voler eliminare TUTTE le statistiche?", | ||||
|     importHandleDescription: "Selezionare 'Ignora gli esistenti' si vuole ignorare l'importazione dei monitoraggi o delle notifiche con lo stesso nome. 'Sovrascrivi' eliminerà ogni monitoraggio e notifica esistente.", | ||||
|     importHandleDescription: "Selezionare \"Ignora esistenti\" se si vuole ignorare l'importazione dei monitor o delle notifiche con lo stesso nome. \"Sovrascrivi\" rimpiazzerà tutti i monitor e le notifiche presenti con quelli nel backup.", | ||||
|     confirmImportMsg: "Si è certi di voler importare il backup? Essere certi di aver selezionato l'opzione corretta di importazione.", | ||||
|     twoFAVerifyLabel: "Scrivi il token per verificare che l'autenticazione a due fattori funzioni", | ||||
|     twoFAVerifyLabel: "Digita il token per verificare che l'autenticazione a due fattori funzioni correttamente:", | ||||
|     tokenValidSettingsMsg: "Il token è valido! È ora possibile salvare le impostazioni.", | ||||
|     confirmEnableTwoFAMsg: "Si è certi di voler abilitare l'autenticazione a due fattori?", | ||||
|     confirmDisableTwoFAMsg: "Si è certi di voler disabilitare l'autenticazione a due fattori?", | ||||
|     Settings: "Impostazioni", | ||||
|     Dashboard: "Cruscotto", | ||||
|     "New Update": "Nuovo Aggiornamento Disponibile", | ||||
|     Dashboard: "Dashboard", | ||||
|     "New Update": "Nuovo aggiornamento disponibile!", | ||||
|     Language: "Lingua", | ||||
|     Appearance: "Aspetto", | ||||
|     Theme: "Tema", | ||||
|     General: "Generali", | ||||
|     General: "Generale", | ||||
|     "Primary Base URL": "URL base primario", | ||||
|     Version: "Versione", | ||||
|     "Check Update On GitHub": "Controlla aggiornamenti su GitHub", | ||||
|     List: "Lista", | ||||
|     Add: "Aggiungi", | ||||
|     "Add New Monitor": "Aggiungi un nuovo monitoraggio", | ||||
|     "Add New Monitor": "Aggiungi nuovo monitor", | ||||
|     "Quick Stats": "Statistiche rapide", | ||||
|     Up: "Su", | ||||
|     Down: "Giù", | ||||
|     Pending: "Pendente", | ||||
|     Up: "Up", | ||||
|     Down: "Down", | ||||
|     Pending: "In attesa", | ||||
|     Unknown: "Sconosciuti", | ||||
|     Pause: "Metti in Pausa", | ||||
|     Pause: "Metti in pausa", | ||||
|     Name: "Nome", | ||||
|     Status: "Stato", | ||||
|     DateTime: "Data e Ora", | ||||
| @@ -63,17 +63,17 @@ export default { | ||||
|     "-hour": "-ore", | ||||
|     Response: "Risposta", | ||||
|     Ping: "Ping", | ||||
|     "Monitor Type": "Tipo di Monitoraggio", | ||||
|     "Monitor Type": "Modalità di monitoraggio", | ||||
|     Keyword: "Parola chiave", | ||||
|     "Friendly Name": "Nomignolo", | ||||
|     "Friendly Name": "Nome", | ||||
|     URL: "URL", | ||||
|     Hostname: "Nome Host", | ||||
|     Port: "Porta", | ||||
|     "Heartbeat Interval": "Intervallo di controllo", | ||||
|     Retries: "Tentativi", | ||||
|     "Heartbeat Retry Interval": "Intervallo tra un tentativo di controllo e l'altro", | ||||
|     "Heartbeat Retry Interval": "Intervallo tra i tentativo di controllo", | ||||
|     Advanced: "Avanzate", | ||||
|     "Upside Down Mode": "Modalità capovolta", | ||||
|     "Upside Down Mode": "Modalità invertita", | ||||
|     "Max. Redirects": "Reindirizzamenti massimi", | ||||
|     "Accepted Status Codes": "Codici di stato accettati", | ||||
|     "Push URL": "Push URL", | ||||
| @@ -81,52 +81,52 @@ export default { | ||||
|     pushOptionalParams: "Parametri aggiuntivi: {0}", | ||||
|     Save: "Salva", | ||||
|     Notifications: "Notifiche", | ||||
|     "Not available, please setup.": "Non disponibili, da impostare.", | ||||
|     "Setup Notification": "Imposta le notifiche", | ||||
|     "Not available, please setup.": "Non disponibili, da configurare.", | ||||
|     "Setup Notification": "Configura le notifiche", | ||||
|     Light: "Chiaro", | ||||
|     Dark: "Scuro", | ||||
|     Auto: "Automatico", | ||||
|     "Theme - Heartbeat Bar": "Tema - Barra di Stato", | ||||
|     "Theme - Heartbeat Bar": "Tema (barra di stato)", | ||||
|     Normal: "Normale", | ||||
|     Bottom: "Sotto", | ||||
|     None: "Nessuna", | ||||
|     Timezone: "Fuso Orario", | ||||
|     "Search Engine Visibility": "Visibilità ai motori di ricerca", | ||||
|     "Allow indexing": "Permetti l'indicizzazione", | ||||
|     "Discourage search engines from indexing site": "Scoraggia l'indicizzazione da parte dei motori di ricerca", | ||||
|     "Change Password": "Cambio Password", | ||||
|     "Current Password": "Password Corrente", | ||||
|     "New Password": "Nuova Password", | ||||
|     "Repeat New Password": "Ripetere la nuova Password", | ||||
|     "Update Password": "Modifica Password", | ||||
|     "Disable Auth": "Disabilita l'autenticazione", | ||||
|     "Enable Auth": "Abilita Autenticazione", | ||||
|     "Allow indexing": "Consenti l'indicizzazione", | ||||
|     "Discourage search engines from indexing site": "Evita l'indicizzazione ai motori di ricerca", | ||||
|     "Change Password": "Cambia password", | ||||
|     "Current Password": "Password corrente", | ||||
|     "New Password": "Nuova password", | ||||
|     "Repeat New Password": "Ripeti nuova password", | ||||
|     "Update Password": "Modifica password", | ||||
|     "Disable Auth": "Disabilita autenticazione", | ||||
|     "Enable Auth": "Abilita autenticazione", | ||||
|     Logout: "Esci", | ||||
|     Leave: "Annulla", | ||||
|     "I understand, please disable": "Lo capisco, disabilitare l'autenticazione.", | ||||
|     Confirm: "Conferma", | ||||
|     Yes: "Sì", | ||||
|     No: "No", | ||||
|     Username: "Nome Utente", | ||||
|     Username: "Nome utente", | ||||
|     Password: "Password", | ||||
|     "Remember me": "Ricordami", | ||||
|     "Remember me": "Ricorda credenziali", | ||||
|     Login: "Accesso", | ||||
|     "No Monitors, please": "Nessun monitoraggio, cortesemente", | ||||
|     "add one": "aggiungerne uno", | ||||
|     "Notification Type": "Tipo di notifica", | ||||
|     "No Monitors, please": "Nessun monitor presente,", | ||||
|     "add one": "aggiungine uno!", | ||||
|     "Notification Type": "Servizio di notifica", | ||||
|     Email: "E-mail", | ||||
|     Test: "Prova", | ||||
|     Test: "Fai una prova", | ||||
|     "Certificate Info": "Informazioni sul certificato", | ||||
|     "Resolver Server": "Server DNS", | ||||
|     "Resource Record Type": "Tipo di Resource Record", | ||||
|     "Last Result": "Ultimo risultato", | ||||
|     "Create your admin account": "Crea l'account amministratore", | ||||
|     "Repeat Password": "Ripeti Password", | ||||
|     "Import Backup": "Importa Backup", | ||||
|     "Export Backup": "Esporta Backup", | ||||
|     "Repeat Password": "Ripeti password", | ||||
|     "Import Backup": "Importa backup", | ||||
|     "Export Backup": "Esporta backup", | ||||
|     Export: "Esporta", | ||||
|     Import: "Importa", | ||||
|     respTime: "Tempo di Risposta (ms)", | ||||
|     respTime: "Tempo di risposta (ms)", | ||||
|     notAvailableShort: "N/D", | ||||
|     "Default enabled": "Abilitato di default", | ||||
|     "Apply on all existing monitors": "Applica su tutti i monitoraggi", | ||||
| @@ -136,21 +136,21 @@ export default { | ||||
|     Heartbeats: "Controlli", | ||||
|     "Auto Get": "Rileva", | ||||
|     backupDescription: "È possibile fare il backup di tutti i monitoraggi e di tutte le notifiche in un file JSON.", | ||||
|     backupDescription2: "P.S.: lo storico e i dati relativi agli eventi non saranno inclusi", | ||||
|     backupDescription3: "Dati sensibili come i token di autenticazione saranno inclusi nel backup, tenere quindi in un luogo sicuro.", | ||||
|     backupDescription2: "NOTA: lo storico e i dati relativi agli eventi non saranno inclusi nel backup", | ||||
|     backupDescription3: "Dati sensibili come i token di autenticazione saranno inclusi nel backup, custodisci il file in un luogo sicuro!", | ||||
|     alertNoFile: "Selezionare il file da importare.", | ||||
|     alertWrongFileType: "Selezionare un file JSON.", | ||||
|     "Clear all statistics": "Pulisci tutte le statistiche", | ||||
|     "Skip existing": "Ignora gli esistenti", | ||||
|     "Clear all statistics": "Cancella tutte le statistiche", | ||||
|     "Skip existing": "Ignora esistenti", | ||||
|     Overwrite: "Sovrascrivi", | ||||
|     Options: "Opzioni", | ||||
|     "Keep both": "Mantieni entrambi", | ||||
|     "Verify Token": "Verifica Token", | ||||
|     "Setup 2FA": "Imposta  l'autenticazione a due fattori", | ||||
|     "Enable 2FA": "Abilita  l'autenticazione a due fattori", | ||||
|     "Disable 2FA": "Disabilita  l'autenticazione a due fattori", | ||||
|     "2FA Settings": "Impostazioni autenticazione a due fattori", | ||||
|     "Two Factor Authentication": "Autenticazione a due fattori", | ||||
|     "Verify Token": "Verifica token", | ||||
|     "Setup 2FA": "Configura 2FA", | ||||
|     "Enable 2FA": "Abilita 2FA", | ||||
|     "Disable 2FA": "Disabilita 2FA", | ||||
|     "2FA Settings": "Gestisci l'autenticazione a due fattori", | ||||
|     "Two Factor Authentication": "Autenticazione a due fattori (2FA)", | ||||
|     Active: "Attivata", | ||||
|     Inactive: "Disattivata", | ||||
|     Token: "Token", | ||||
| @@ -173,33 +173,33 @@ export default { | ||||
|     "Avg. Ping": "Tempo medio di risposta al ping", | ||||
|     "Avg. Response": "Tempo medio di risposta", | ||||
|     "Entry Page": "Pagina Principale", | ||||
|     statusPageNothing: "Non c'è nulla qui, aggiungere un gruppo oppure un monitoraggio.", | ||||
|     "No Services": "Nessun Servizio", | ||||
|     statusPageNothing: "Non c'è nulla qui, aggiungi un gruppo oppure un monitor.", | ||||
|     "No Services": "Nessun servizio", | ||||
|     "All Systems Operational": "Tutti i sistemi sono funzionali", | ||||
|     "Partially Degraded Service": "Servizio parzialmente degradato", | ||||
|     "Degraded Service": "Servizio degradato", | ||||
|     "Add Group": "Aggiungi Gruppo", | ||||
|     "Add a monitor": "Aggiungi un monitoraggio", | ||||
|     "Add Group": "Aggiungi gruppo", | ||||
|     "Add a monitor": "Aggiungi monitor", | ||||
|     "Edit Status Page": "Modifica pagina di stato", | ||||
|     "Go to Dashboard": "Vai al Cruscotto", | ||||
|     "Go to Dashboard": "Vai alla dashboard", | ||||
|     "Status Page": "Pagina di stato", | ||||
|     defaultNotificationName: "Allarme {notification} ({number})", | ||||
|     defaultNotificationName: "Notifica {notification} ({number})", | ||||
|     here: "qui", | ||||
|     "Required": "Richiesto", | ||||
|     "telegram": "Telegram", | ||||
|     "Bot Token": "Token del Bot", | ||||
|     "You can get a token from": "Puoi ricevere un token da", | ||||
|     Required: "Obbligatorio", | ||||
|     telegram: "Telegram", | ||||
|     "Bot Token": "Token del bot", | ||||
|     wayToGetTelegramToken: "Puoi ottenere il token da {0}.", | ||||
|     "Chat ID": "ID Chat", | ||||
|     supportTelegramChatID: "Supporta Chat dirette / di Gruppo / ID Canale", | ||||
|     wayToGetTelegramChatID: "Puoi ricereve l'ID chat mandando un messaggio al bot andando in questo url per visualizzare il chat_id:", | ||||
|     supportTelegramChatID: "Supporta chat private, gruppi e canali.", | ||||
|     wayToGetTelegramChatID: "È possibile ricereve l'ID chat mandando un messaggio al bot e poi andando in questo URL per visualizzare il chat_id:", | ||||
|     "YOUR BOT TOKEN HERE": "QUI IL TOKEN DEL BOT", | ||||
|     chatIDNotFound: "Non trovo l'ID chat. Prima bisogna mandare un messaggio al bot", | ||||
|     "webhook": "Webhook", | ||||
|     webhook: "Webhook", | ||||
|     "Post URL": "Post URL", | ||||
|     "Content Type": "Content Type", | ||||
|     webhookJsonDesc: "{0} va bene per qualsiasi server http moderno ad esempio express.js", | ||||
|     webhookJsonDesc: "{0} va bene per qualsiasi server HTTP moderno ad esempio express.js", | ||||
|     webhookFormDataDesc: "{multipart} va bene per PHP, c'è solo bisogno di analizzare il json con {decodeFunction}", | ||||
|     "smtp": "E-mail (SMTP)", | ||||
|     smtp: "E-mail (SMTP)", | ||||
|     secureOptionNone: "Nessuno / STARTTLS (25, 587)", | ||||
|     secureOptionTLS: "TLS (465)", | ||||
|     "Ignore TLS Error": "Ignora gli errori TLS", | ||||
| @@ -208,26 +208,26 @@ export default { | ||||
|     "To Email": "Destinatario", | ||||
|     smtpCC: "CC", | ||||
|     smtpBCC: "CCn", | ||||
|     "discord": "Discord", | ||||
|     discord: "Discord", | ||||
|     "Discord Webhook URL": "URL Webhook di Discord", | ||||
|     wayToGetDiscordURL: "È possibile recuperarlo da Impostazioni server -> Integrazioni -> Creare Webhook", | ||||
|     "Bot Display Name": "Nome del Bot", | ||||
|     "Prefix Custom Message": "Prefisso per il messaggio personalizzato", | ||||
|     "Hello @everyone is...": "Ciao a {'@'}everyone ...", | ||||
|     "teams": "Microsoft Teams", | ||||
|     teams: "Microsoft Teams", | ||||
|     "Webhook URL": "URL Webhook", | ||||
|     wayToGetTeamsURL: "È possibile imparare a creare un URL Webhook {0}.", | ||||
|     "signal": "Signal", | ||||
|     "Number": "Numero", | ||||
|     "Recipients": "Destinatari", | ||||
|     signal: "Signal", | ||||
|     Number: "Numero", | ||||
|     Recipients: "Destinatari", | ||||
|     needSignalAPI: "È necessario avere un client Signal con le API REST.", | ||||
|     wayToCheckSignalURL: "Controllare questo url per capire come impostarne uno:", | ||||
|     signalImportant: "IMPORTANTE: Non è possibile mischiare gruppi e numeri all'interno dei destinatari!", | ||||
|     "gotify": "Gotify", | ||||
|     gotify: "Gotify", | ||||
|     "Application Token": "Token Applicazione", | ||||
|     "Server URL": "URL Server", | ||||
|     "Priority": "Priorità", | ||||
|     "slack": "Slack", | ||||
|     Priority: "Priorità", | ||||
|     slack: "Slack", | ||||
|     "Icon Emoji": "Icona Emoji", | ||||
|     "Channel Name": "Nome Canale", | ||||
|     "Uptime Kuma URL": "Indirizzo Uptime Kuma", | ||||
| @@ -247,7 +247,7 @@ export default { | ||||
|     line: "Line Messenger", | ||||
|     mattermost: "Mattermost", | ||||
|     "User Key": "Chiave Utente", | ||||
|     "Device": "Dispositivo", | ||||
|     Device: "Dispositivo", | ||||
|     "Message Title": "Titolo Messaggio", | ||||
|     "Notification Sound": "Suono di Notifica", | ||||
|     "More info on:": "Maggiori informazioni su: {0}", | ||||
| @@ -281,7 +281,7 @@ export default { | ||||
|     "Icon URL": "URL Icona", | ||||
|     aboutIconURL: "È possibile impostare un collegameno a una immagine in \"URL Icona\" per modificare l'immagine di profilo. Non verrà utilizzata se è impostata l'Icona Emoji.", | ||||
|     aboutMattermostChannelName: "È possibile modificare il canale predefinito che dove il webhook manda messaggi immettendo il nome del canale nel campo \"Nome Canale\". Questo va abilitato nelle impostazioni webhook di Mattermost webhook. P.E.: #altro-canale", | ||||
|     "matrix": "Matrix", | ||||
|     matrix: "Matrix", | ||||
|     promosmsTypeEco: "SMS ECO - economico, ma lento e spesso sovraccarico. Limitato solamente a destinatari Polacchi.", | ||||
|     promosmsTypeFlash: "SMS FLASH - Il messaggio sarà automaticamente mostrato sul dispositivo dei destinatari. Limitato solo a destinatari Polacchi.", | ||||
|     promosmsTypeFull: "SMS FULL - Premium, È possibile utilizzare il proprio come come mittente (è necessario prima registrare il nome). Affidabile per gli allarmi.", | ||||
| @@ -294,62 +294,71 @@ export default { | ||||
|     matrixDesc1: "È possibile recuperare l'ID della stanza all'interno delle impostazioni avanzate della stanza nel client Matrix. Dovrebbe essere simile a !QMdRCpUIfLwsfjxye6:server.di.casa.", | ||||
|     matrixDesc2: "È altamente raccomandata la creazione di un nuovo utente e di non utilizare il proprio token di accesso Matrix poiché darà pieno controllo al proprio account e a tutte le stanze in cui si ha accesso. Piuttosto, si crei un nuovo utente per invitarlo nella stanza dove si vuole ricevere le notifiche. Si può accedere al token eseguendo {0}", | ||||
|     Method: "Metodo", | ||||
|     Body: "Corpo", | ||||
|     Body: "Body", | ||||
|     Headers: "Intestazioni", | ||||
|     PushUrl: "URL di Push", | ||||
|     HeadersInvalidFormat: "L'intestazione di richiesta non è un JSON valido: ", | ||||
|     BodyInvalidFormat: "Il corpo di richiesta non è un JSON valido: ", | ||||
|     "Monitor History": "Storico monitoraggio", | ||||
|     "Monitor History": "Storico monitor", | ||||
|     clearDataOlderThan: "Mantieni lo storico per {0} giorni.", | ||||
|     PasswordsDoNotMatch: "Le password non corrispondono.", | ||||
|     PasswordsDoNotMatch: "Le password non corrispondono!", | ||||
|     records: "records", | ||||
|     "One record": "One record", | ||||
|     steamApiKeyDescription: "Per monitorare un server di gioco Steam si necessita della chiave Web-API di Steam. È possibile registrare la propria chiave API qui: ", | ||||
|     steamApiKeyDescription: "Per monitorare un server di gioco Steam è necessaria una Web-API Key di Steam. È possibile registrarne una qui: ", | ||||
|     "Current User": "Utente corrente", | ||||
|     recent: "Recenti", | ||||
|     Done: "Fatto", | ||||
|     Info: "Info", | ||||
|     Security: "Sicurezza", | ||||
|     "Steam API Key": "Chiave API di Steam", | ||||
|     "Shrink Database": "Comprimi Database", | ||||
|     "Steam API Key": "API Key di Steam", | ||||
|     "Shrink Database": "Comprimi database", | ||||
|     "Pick a RR-Type...": "Scegli un tipo di RR...", | ||||
|     "Pick Accepted Status Codes...": "Scegli i codici di Stato Accettati...", | ||||
|     Default: "Predefinito", | ||||
|     "HTTP Options": "Opzioni HTTP", | ||||
|     "Create Incident": "Crea Incident", | ||||
|     "Create Incident": "Segnala incidente", | ||||
|     Title: "Titolo", | ||||
|     Content: "Contenuto", | ||||
|     Style: "Stile", | ||||
|     info: "informativo", | ||||
|     warning: "attenzione", | ||||
|     danger: "critico", | ||||
|     primary: "primario", | ||||
|     primary: "predefinito", | ||||
|     light: "chiaro", | ||||
|     dark: "scuro", | ||||
|     Post: "Posta", | ||||
|     "Please input title and content": "Inserire il titolo e il contenuto", | ||||
|     Created: "Creato", | ||||
|     "Last Updated": "Ultima modifica", | ||||
|     Unpin: "Stacca", | ||||
|     "Switch to Light Theme": "Utilizza tema chiaro", | ||||
|     "Switch to Dark Theme": "Utilizza tema scuro", | ||||
|     Unpin: "Rimuovi", | ||||
|     "Switch to Light Theme": "Utilizza il tema chiaro", | ||||
|     "Switch to Dark Theme": "Utilizza il tema scuro", | ||||
|     "Show Tags": "Mostra etichette", | ||||
|     "Hide Tags": "Nascondi etichette", | ||||
|     Description: "Descrizione", | ||||
|     "No monitors available.": "Nessun monitoraggio disponibile.", | ||||
|     "Add one": "Aggiungi", | ||||
|     "No Monitors": "Nessun monitoraggio", | ||||
|     "Add one": "Aggiungi", | ||||
|     "No monitors available.": "Nessun monitor disponibile.", | ||||
|     "Add one": "Aggiungine uno!", | ||||
|     "No Monitors": "Nessun monitor presente.", | ||||
|     "Untitled Group": "Gruppo senza titolo", | ||||
|     Services: "Servizi", | ||||
|     Discard: "Scarta", | ||||
|     Discard: "Scarta modifiche", | ||||
|     Cancel: "Annulla", | ||||
|     "Powered by": "Servito da", | ||||
|     shrinkDatabaseDescription: "Lancia il comando VACUUM sul database SQLite. Se il database è stato creato dopo la versione 1.10.0, AUTO_VACUUM è già abilitato e questa azione non è necessaria.", | ||||
|     "Powered by": "Powered by", | ||||
|     shrinkDatabaseDescription: "Lancia il comando \"VACUUM\" sul database SQLite. Se il database è stato creato dopo la versione 1.10.0, la funzione \"AUTO_VACUUM\" è già abilitata di default e quindi questa azione non è necessaria.", | ||||
|     serwersms: "SerwerSMS.pl", | ||||
|     serwersmsAPIUser: "Nome utente API (incl. prefisso webapi_)", | ||||
|     serwersmsAPIPassword: "Password API", | ||||
|     serwersmsPhoneNumber: "Numero di Telefono", | ||||
|     serwersmsSenderName: "Nome del mittente SMS (registrato via portale cliente)", | ||||
|     "stackfield": "Stackfield", | ||||
|     stackfield: "Stackfield", | ||||
|     smtpDkimSettings: "Impostazioni DKIM", | ||||
|     smtpDkimDesc: "Fare riferimento a Nodemailer DKIM {0} per l'utilizzo.", | ||||
|     documentation: "documentazione", | ||||
|     smtpDkimDomain: "Dominio", | ||||
|     smtpDkimKeySelector: "Selettore Chiave", | ||||
|     smtpDkimPrivateKey: "Chiave Privata", | ||||
|     smtpDkimHashAlgo: "Algoritmo di hashing (opzionale)", | ||||
|     smtpDkimheaderFieldNames: "Campi Intestazione da firmare (opzionale)", | ||||
|     smtpDkimskipFields: "Campi Intestazione da non firmare (opzionale)", | ||||
|     GoogleChat: "Google Chat (solo per Google Workspace)", | ||||
| }; | ||||
|   | ||||
| @@ -12,7 +12,7 @@ export default { | ||||
|     pauseDashboardHome: "一時停止", | ||||
|     deleteMonitorMsg: "この監視を削除してよろしいですか?", | ||||
|     deleteNotificationMsg: "全ての監視のこの通知を削除してよろしいですか?", | ||||
|     resoverserverDescription: "Cloudflareがデフォルトのサーバーですが、いつでもリゾルバサーバーを変更できます。", | ||||
|     resolverserverDescription: "Cloudflareがデフォルトのサーバーですが、いつでもリゾルバサーバーを変更できます。", | ||||
|     rrtypeDescription: "監視するRRタイプを選択します", | ||||
|     pauseMonitorMsg: "一時停止しますか?", | ||||
|     Settings: "設定", | ||||
|   | ||||
| @@ -13,7 +13,7 @@ export default { | ||||
|     pauseDashboardHome: "일시 정지", | ||||
|     deleteMonitorMsg: "정말 이 모니터링을 삭제할까요?", | ||||
|     deleteNotificationMsg: "정말 이 알림을 모든 모니터링에서 삭제할까요?", | ||||
|     resoverserverDescription: "Cloudflare가 기본 서버예요, 원한다면 언제나 다른 Resolver 서버로 변경할 수 있어요.", | ||||
|     resolverserverDescription: "Cloudflare가 기본 서버예요, 원한다면 언제나 다른 Resolver 서버로 변경할 수 있어요.", | ||||
|     rrtypeDescription: "모니터링할 RR-Type을 선택해요.", | ||||
|     pauseMonitorMsg: "정말 이 모니터링을 일시 정지할까요?", | ||||
|     enableDefaultNotificationDescription: "새로 추가하는 모든 모니터링에 이 알림을 기본적으로 활성화해요. 각 모니터에 대해 별도로 알림을 비활성화할 수 있어요.", | ||||
| @@ -194,7 +194,7 @@ export default { | ||||
|     "Post URL": "Post URL", | ||||
|     "Content Type": "Content Type", | ||||
|     webhookJsonDesc: "{0}은 express.js와 같은 최신 HTTP 서버에 적합해요.", | ||||
|     webhookFormDataDesc: "{multipart}은 PHP에 적합해요. {decodeFunction}를 기준으로 json을 디코딩하면 돼요.", | ||||
|     webhookFormDataDesc: "{multipart}은 PHP에 적합해요. {decodeFunction}를 기준으로 json을 디코딩하면 되어요.", | ||||
|     smtp: "Email (SMTP)", | ||||
|     secureOptionNone: "없음 / STARTTLS (25, 587)", | ||||
|     secureOptionTLS: "TLS (465)", | ||||
| @@ -245,7 +245,7 @@ export default { | ||||
|     "Message Title": "메시지 제목", | ||||
|     "Notification Sound": "알림음", | ||||
|     "More info on:": "자세한 정보: {0}", | ||||
|     pushoverDesc1: "긴급 우선 순위 (2)는 재시도 사이에 기본적으로 30초의 타임아웃이 있고, 1시간 후에 만료돼요.", | ||||
|     pushoverDesc1: "긴급 우선 순위 (2)는 재시도 사이에 기본적으로 30초의 타임아웃이 있고, 1시간 후에 만료되어요.", | ||||
|     pushoverDesc2: "다른 장치에 알림을 보내려면 장치칸을 입력해주세요.", | ||||
|     "SMS Type": "SMS 종류", | ||||
|     octopushTypePremium: "프리미엄 (빠름) - 알림 기능에 적합해요)", | ||||
| @@ -270,13 +270,85 @@ export default { | ||||
|     "Messaging API": "Messaging API 메뉴", | ||||
|     wayToGetLineChannelToken: "먼저 {0}에 액세스하고, 공급자 및 채널 (Messaging API)을 만든 다음, 각 메뉴 밑에 언급된 메뉴에서 채널 액세스 토큰과 사용자 ID를 얻을 수 있어요.", | ||||
|     "Icon URL": "아이콘 URL", | ||||
|     aboutIconURL: "\"Icon URL\"에 사진 링크를 입력해 프로필 사진을 설정할 수 있어요. 아이콘 이모지가 설정되어 있으면 적용되지 않을 거예요.", | ||||
|     aboutIconURL: "\"아이콘 URL\"에 사진 링크를 입력해 프로필 사진을 설정할 수 있어요. 아이콘 이모지가 설정되어 있으면 적용되지 않을 거예요.", | ||||
|     aboutMattermostChannelName: "채널 이름을 입력하면 Webhook이 게시할 기본 채널을 재설정할 수 있어요. 이 설정은 Mattermost 웹훅 설정에서 활성화해야 해요. 예: #기타-채널", | ||||
|     matrix: "매트릭스", | ||||
|     matrix: "Matrix", | ||||
|     promosmsTypeEco: "SMS ECO - 저렴하지만 느리고 가끔 과부하에 걸려요. 폴란드 수신자만 사용할 수 있어요. ", | ||||
|     promosmsTypeFlash: "SMS FLASH - 메시지가 받는 사람 장치에 자동으로 표시돼요. 폴란드 수신자만 사용할 수 있어요.", | ||||
|     promosmsTypeFlash: "SMS FLASH - 메시지가 받는 사람 장치에 자동으로 표시되어요. 폴란드 수신자만 사용할 수 있어요.", | ||||
|     promosmsTypeFull: "SMS FULL - SMS 프리미엄 티어, 보내는 사람 이름을 먼저 등록해야 해요. 알림 기능에 적합해요.", | ||||
|     promosmsTypeSpeed: "SMS SPEED - 시스템에서 가장 높은 우선순위예요. 매우 빠르고 신뢰할 수 있지만 비용이 많이 들어요 (SMS 전체 가격의 약 두 배).", | ||||
|     promosmsPhoneNumber: "전화 번호 (폴란드 수신자라면 지역번호를 적지 않아도 돼요.)", | ||||
|     promosmsPhoneNumber: "전화 번호 (폴란드 수신자라면 지역번호를 적지 않아도 되어요.)", | ||||
|     promosmsSMSSender: "SMS 보내는 사람 이름 : 미리 등록된 이름 혹은 기본값 중 하나예요: InfoSMS, SMS Info, MaxSMS, INFO, SMS", | ||||
|     "Primary Base URL": "기본 URL", | ||||
|     "Push URL": "Push URL", | ||||
|     needPushEvery: "You should call this URL every {0} seconds.", | ||||
|     pushOptionalParams: "Optional parameters: {0}", | ||||
|     emailCustomSubject: "Custom Subject", | ||||
|     clicksendsms: "ClickSend SMS", | ||||
|     checkPrice: "{0} 가격 확인:", | ||||
|     apiCredentials: "API credentials", | ||||
|     octopushLegacyHint: "Octopush 레거시 버전 (2011-2020) 을 사용하시나요? 아니면 새 버전을 사용하시나요?", | ||||
|     "Feishu WebHookUrl": "Feishu WebHookURL", | ||||
|     matrixHomeserverURL: "Homeserver URL (with http(s):// and optionally port)", | ||||
|     "Internal Room Id": "내부 방 ID", | ||||
|     matrixDesc1: "Matrix 클라이언트 방 설정의 고급 섹션에서 내부 방 ID를 찾을 수 있어요. 내부 방 ID는 이렇게 생겼답니다: !QMdRCpUIfLwsfjxye6:home.server.", | ||||
|     matrixDesc2: "사용자의 모든 방에 대한 엑세스가 허용될 수 있어서 새로운 사용자를 만들고 원하는 방에만 초대한 후 엑세스 토큰을 사용하는 것이 좋아요. {0} 이 명령어를 통해 엑세스 토큰을 얻을 수 있어요.", | ||||
|     Method: "Method", | ||||
|     Body: "Body", | ||||
|     Headers: "Headers", | ||||
|     PushUrl: "Push URL", | ||||
|     HeadersInvalidFormat: "요청 Headers의 JSON 형식이 올바르지 않아요: ", | ||||
|     BodyInvalidFormat: "요청 Body의 JSON 형식이 올바르지 않아요: ", | ||||
|     "Monitor History": "모니터링 기록", | ||||
|     clearDataOlderThan: "모니터링 기록을 {0}일 동안 저장해요.", | ||||
|     PasswordsDoNotMatch: "비밀번호가 일치하지 않아요.", | ||||
|     records: "records", | ||||
|     "One record": "One record", | ||||
|     steamApiKeyDescription: "스팀 게임 서버를 모니터링하려면 Steam Web API 키가 필요해요. API 키는 하단 사이트에서 등록할 수 있어요: ", | ||||
|     "Current User": "현재 사용자", | ||||
|     recent: "최근", | ||||
|     Done: "완료", | ||||
|     Info: "정보", | ||||
|     Security: "보안", | ||||
|     "Steam API Key": "Steam API Key", | ||||
|     "Shrink Database": "데이터베이스 축소", | ||||
|     "Pick a RR-Type...": "RR-Type을 골라주세요...", | ||||
|     "Pick Accepted Status Codes...": "상태 코드를 골라주세요...", | ||||
|     Default: "기본", | ||||
|     "HTTP Options": "HTTP 옵션", | ||||
|     "Create Incident": "인시던트 만들기", | ||||
|     Title: "제목", | ||||
|     Content: "내용", | ||||
|     Style: "스타일", | ||||
|     info: "정보", | ||||
|     warning: "경고", | ||||
|     danger: "위험", | ||||
|     primary: "기본", | ||||
|     light: "라이트", | ||||
|     dark: "다크", | ||||
|     Post: "올리기", | ||||
|     "Please input title and content": "제목과 내용을 작성해주세요.", | ||||
|     Created: "생성 날짜", | ||||
|     "Last Updated": "마지막 업데이트", | ||||
|     Unpin: "제거", | ||||
|     "Switch to Light Theme": "라이트 테마로 전환", | ||||
|     "Switch to Dark Theme": "다크 테마로 전환", | ||||
|     "Show Tags": "태그 보이기", | ||||
|     "Hide Tags": "태그 숨기기", | ||||
|     Description: "설명", | ||||
|     "No monitors available.": "모니터링이 없어요.", | ||||
|     "Add one": "추가하기", | ||||
|     "No Monitors": "모니터링 없음", | ||||
|     "Untitled Group": "이름없는 그룹", | ||||
|     Services: "서비스", | ||||
|     Discard: "취소", | ||||
|     Cancel: "취소", | ||||
|     "Powered by": "Powered by", | ||||
|     shrinkDatabaseDescription: "SQLite 데이터베이스 VACUUM을 트리거해요. 만약 데이터베이스가 1.10.0 버전 이후에 생성되었다면 AUTO_VACUUM이 설정되어 있어 이 작업은 필요 없을 거에요.", | ||||
|     serwersms: "SerwerSMS.pl", | ||||
|     serwersmsAPIUser: "API Usename (webapi_ 접두사 포함)", | ||||
|     serwersmsAPIPassword: "API 비밀번호", | ||||
|     serwersmsPhoneNumber: "휴대전화 번호", | ||||
|     serwersmsSenderName: "보내는 사람 이름 (registered via customer portal)", | ||||
|     stackfield: "Stackfield", | ||||
| }; | ||||
|   | ||||
| @@ -4,24 +4,24 @@ export default { | ||||
|     retryCheckEverySecond: "Prøv igjen hvert {0} sekund.", | ||||
|     retriesDescription: "Maksimalt antall forsøk før tjenesten er merket som nede og et varsel sendes", | ||||
|     ignoreTLSError: "Ignorer TLS/SSL-feil for HTTPS-nettsteder", | ||||
|     upsideDownModeDescription: "Snu statusen opp ned. Hvis tjenesten er tilgjengelig, er den NED.", | ||||
|     upsideDownModeDescription: "Snu statusen opp ned. Hvis tjenesten er tilgjengelig, er den NEDE.", | ||||
|     maxRedirectDescription: "Maksimalt antall viderekoblinger å følge. Sett til 0 for å deaktivere viderekoblinger.", | ||||
|     acceptedStatusCodesDescription: "Velg statuskoder som anses som et vellykket svar.", | ||||
|     acceptedStatusCodesDescription: "Velg statuskoder som anses som en vellykket respons.", | ||||
|     passwordNotMatchMsg: "Passordene stemmer ikke overens.", | ||||
|     notificationDescription: "Tilordne et varsel for å overvåkningen for å få det til å fungere.", | ||||
|     keywordDescription: "Søk etter nøkkelord i vanlig HTML eller JSON, og det er versalfølsom", | ||||
|     notificationDescription: "Varsler må tilordnes en overvåkning for å fungere.", | ||||
|     keywordDescription: "Søk etter nøkkelord i ren HTML eller JSON. Søket skiller mellom store og små bokstaver.", | ||||
|     pauseDashboardHome: "Pause", | ||||
|     deleteMonitorMsg: "Er du sikker på at du vil slette denne overvåkningen?", | ||||
|     deleteNotificationMsg: "Er du sikker på at du vil slette dette varselet for alle overvåkningene?", | ||||
|     resoverserverDescription: "Cloudflare er standardserveren, kan du når som helst endre DNS-serveren.", | ||||
|     resolverserverDescription: "Cloudflare er standardserveren. Du kan endre DNS-serveren når som helst.", | ||||
|     rrtypeDescription: "Velg RR-typen du vil overvåke", | ||||
|     pauseMonitorMsg: "Er du sikker på at du vil sette en pause?", | ||||
|     pauseMonitorMsg: "Er du sikker på at du vil sette på pause?", | ||||
|     enableDefaultNotificationDescription: "For hver ny overvåkning vil denne varslingen være aktivert som standard. Du kan fortsatt deaktivere varselet separat for hver overvåkning.", | ||||
|     clearEventsMsg: "Er du sikker på at du vil slette alle hendelser for denne overvåkningen?", | ||||
|     clearHeartbeatsMsg: "Er du sikker på at du vil slette alle hjerteslag for denne overvåkningen?", | ||||
|     confirmClearStatisticsMsg: "Er du sikker på at du vil slette ALL statistikk?", | ||||
|     importHandleDescription: "Velg 'Hopp over eksisterende' hvis du vil hoppe over hver overvåkning eller varsel med samme navn. 'Overskriv' sletter alle eksisterende overvåkninger og varsler.", | ||||
|     confirmImportMsg: "Er du sikker på å importere sikkerhetskopien? Sørg for at du har valgt riktig importalternativ.", | ||||
|     confirmImportMsg: "Er du sikker på at du vil importere denne sikkerhetskopien? Sørg for at du har valgt riktig importalternativ.", | ||||
|     twoFAVerifyLabel: "Skriv inn tokenet ditt for å bekrefte at 2FA fungerer", | ||||
|     tokenValidSettingsMsg: "Token er gyldig! Du kan nå lagre 2FA-innstillingene.", | ||||
|     confirmEnableTwoFAMsg: "Er du sikker på at du vil aktivere 2FA?", | ||||
| @@ -50,7 +50,7 @@ export default { | ||||
|     Message: "Melding", | ||||
|     "No important events": "Ingen viktige hendelser", | ||||
|     Resume: "Fortsett", | ||||
|     Edit: "Endre", | ||||
|     Edit: "Rediger", | ||||
|     Delete: "Slett", | ||||
|     Current: "Nåværende", | ||||
|     Uptime: "Oppetid", | ||||
| @@ -77,7 +77,7 @@ export default { | ||||
|     "Accepted Status Codes": "Godkjente statuskoder", | ||||
|     Save: "Lagre", | ||||
|     Notifications: "Varsler", | ||||
|     "Not available, please setup.": "Ikke tilgjengelig, sett opp.", | ||||
|     "Not available, please setup.": "Ikke tilgjengelig, venligst sett opp.", | ||||
|     "Setup Notification": "Sett opp varsel", | ||||
|     Light: "Lys", | ||||
|     Dark: "Mørk", | ||||
| @@ -87,9 +87,9 @@ export default { | ||||
|     Bottom: "Bunn", | ||||
|     None: "Ingen", | ||||
|     Timezone: "Tidssone", | ||||
|     "Search Engine Visibility": "Søkemotor synlighet", | ||||
|     "Search Engine Visibility": "Søkemotor-synlighet", | ||||
|     "Allow indexing": "Tillat indeksering", | ||||
|     "Discourage search engines from indexing site": "Avskrekk søkemotorer fra å indeksere nettstedet", | ||||
|     "Discourage search engines from indexing site": "Fraråd søkemotorer fra å indeksere nettstedet", | ||||
|     "Change Password": "Endre passord", | ||||
|     "Current Password": "Nåværende passord", | ||||
|     "New Password": "Nytt passord", | ||||
| @@ -99,7 +99,7 @@ export default { | ||||
|     "Enable Auth": "Aktiver autentisering", | ||||
|     Logout: "Logg ut", | ||||
|     Leave: "Forlat", | ||||
|     "I understand, please disable": "Jeg forstår, deaktiver", | ||||
|     "I understand, please disable": "Jeg forstår, vennligst deaktiver", | ||||
|     Confirm: "Bekreft", | ||||
|     Yes: "Ja", | ||||
|     No: "Nei", | ||||
| @@ -125,15 +125,15 @@ export default { | ||||
|     respTime: "Svartid (ms)", | ||||
|     notAvailableShort: "N/A", | ||||
|     "Default enabled": "Standard aktivert", | ||||
|     "Apply on all existing monitors": "Påfør på alle eksisterende overvåkninger", | ||||
|     "Apply on all existing monitors": "Anvend for alle eksisterende overvåkninger", | ||||
|     Create: "Opprett", | ||||
|     "Clear Data": "Slett data", | ||||
|     Events: "Hendelser", | ||||
|     Heartbeats: "Hjerteslag", | ||||
|     "Auto Get": "Auto Get", | ||||
|     "Auto Get": "Auto Hent", | ||||
|     backupDescription: "Du kan sikkerhetskopiere alle overvåkninger og alle varsler til en JSON-fil.", | ||||
|     backupDescription2: "PS: Historikk og hendelsesdata er ikke inkludert.", | ||||
|     backupDescription3: "Følsomme data som varslingstokener er inkludert i eksportfilen. Vennligst oppbevar dem nøye.", | ||||
|     backupDescription3: "Følsomme data som varslingstokener er inkludert i eksportfilen. Vennligst oppbevar dem sikkert.", | ||||
|     alertNoFile: "Velg en fil som skal importeres.", | ||||
|     alertWrongFileType: "Velg en JSON-fil.", | ||||
|     "Clear all statistics": "Fjern all statistikk", | ||||
| @@ -154,7 +154,7 @@ export default { | ||||
|     Tags: "Etiketter", | ||||
|     "Add New below or Select...": "Legg til nytt nedenfor eller Velg ...", | ||||
|     "Tag with this name already exist.": "Etikett med dette navnet eksisterer allerede.", | ||||
|     "Tag with this value already exist.": "Etikett med denne verdien finnes allerede.", | ||||
|     "Tag with this value already exist.": "Etikett med denne verdien eksisterer allerede.", | ||||
|     color: "farge", | ||||
|     "value (optional)": "verdi (valgfritt)", | ||||
|     Gray: "Grå", | ||||
| @@ -172,29 +172,29 @@ export default { | ||||
|     statusPageNothing: "Ingenting her, vennligst legg til en gruppe eller en overvåkning.", | ||||
|     "No Services": "Ingen tjenester", | ||||
|     "All Systems Operational": "Alle systemer i drift", | ||||
|     "Partially Degraded Service": "Delvis degradert drift", | ||||
|     "Degraded Service": "Degradert drift", | ||||
|     "Partially Degraded Service": "Delvis degradert tjeneste", | ||||
|     "Degraded Service": "Degradert tjeneste", | ||||
|     "Add Group": "Legg til gruppe", | ||||
|     "Add a monitor": "Legg til en overvåkning", | ||||
|     "Edit Status Page": "Rediger statusside", | ||||
|     "Go to Dashboard": "Gå til Dashboard", | ||||
|     "Status Page": "Statusside", | ||||
|     defaultNotificationName: "Min {notification} varsling ({number})", | ||||
|     here: "here", | ||||
|     here: "her", | ||||
|     Required: "Obligatorisk", | ||||
|     telegram: "Telegram", | ||||
|     "Bot Token": "Bot Token", | ||||
|     wayToGetTelegramToken: "Du kan få et token fra {0}.", | ||||
|     "Chat ID": "Chat ID", | ||||
|     supportTelegramChatID: "Support Direct Chat / Group / Channel's Chat ID", | ||||
|     wayToGetTelegramChatID: "Du kan få chat-ID-en din ved å sende meldingen til boten og gå til denne nettadressen for å se chat_id:", | ||||
|     wayToGetTelegramChatID: "Du kan få chat-ID-en din ved å sende en melding til boten og gå til denne nettadressen for å se chat_id:", | ||||
|     "YOUR BOT TOKEN HERE": "DITT BOT TOKEN HER", | ||||
|     chatIDNotFound: "Chat-ID ble ikke funnet. Send en melding til denne boten først", | ||||
|     webhook: "Webhook", | ||||
|     "Post URL": "Post URL", | ||||
|     "Content Type": "Content Type", | ||||
|     "Content Type": "Innholdstype", | ||||
|     webhookJsonDesc: "{0} er bra for alle moderne HTTP-servere som express.js", | ||||
|     webhookFormDataDesc: "{multipart} er bra for PHP, du trenger bare å analysere JSON etter {decodeFunction}", | ||||
|     webhookFormDataDesc: "{multipart} er bra for PHP. JSON trenger å bli analysert med {decodeFunction}", | ||||
|     smtp: "E-post (SMTP)", | ||||
|     secureOptionNone: "None / STARTTLS (25, 587)", | ||||
|     secureOptionTLS: "TLS (465)", | ||||
| @@ -205,7 +205,7 @@ export default { | ||||
|     smtpBCC: "BCC", | ||||
|     discord: "Discord", | ||||
|     "Discord Webhook URL": "Discord Webhook URL", | ||||
|     wayToGetDiscordURL: "Du kan få dette ved å gå til Serverinnstillinger -> Integrasjoner -> Webhooks -> Ny webhook", | ||||
|     wayToGetDiscordURL: "Du kan få denne ved å gå til Serverinnstillinger -> Integrasjoner -> Opprett en Webhook", | ||||
|     "Bot Display Name": "Bot Visningsnavn", | ||||
|     "Prefix Custom Message": "Prefiks tilpasset melding", | ||||
|     "Hello @everyone is...": "Hei {'@'}everyone det er...", | ||||
| @@ -240,43 +240,43 @@ export default { | ||||
|     pushbullet: "Pushbullet", | ||||
|     line: "Line Messenger", | ||||
|     mattermost: "Mattermost", | ||||
|     "User Key": "User Key", | ||||
|     Device: "Device", | ||||
|     "Message Title": "Message Title", | ||||
|     "Notification Sound": "Notification Sound", | ||||
|     "More info on:": "More info on: {0}", | ||||
|     pushoverDesc1: "Emergency priority (2) has default 30 second timeout between retries and will expire after 1 hour.", | ||||
|     pushoverDesc2: "If you want to send notifications to different devices, fill out Device field.", | ||||
|     "User Key": "Bruker-nøkkel", | ||||
|     Device: "Enhet", | ||||
|     "Message Title": "Meldingstittel", | ||||
|     "Notification Sound": "Notifikasjonslyd", | ||||
|     "More info on:": "Mer info på: {0}", | ||||
|     pushoverDesc1: "Nødsprioritet (2) har en standard 30 sekunders tidsavbrudd mellom forsøk og vil utløpe etter 1 time.", | ||||
|     pushoverDesc2: "Hvis du vil sende varsler til forskjellige enheteter, fyll ut Enhet-feltet.", | ||||
|     "SMS Type": "SMS Type", | ||||
|     octopushTypePremium: "Premium (Fast - recommended for alerting)", | ||||
|     octopushTypeLowCost: "Low Cost (Slow, sometimes blocked by operator)", | ||||
|     "Check octopush prices": "Check octopush prices {0}.", | ||||
|     octopushPhoneNumber: "Phone number (intl format, eg : +33612345678) ", | ||||
|     octopushSMSSender: "SMS Sender Name : 3-11 alphanumeric characters and space (a-zA-Z0-9)", | ||||
|     "LunaSea Device ID": "LunaSea Device ID", | ||||
|     octopushTypePremium: "Premium (Raskt - anbefalt for varsling)", | ||||
|     octopushTypeLowCost: "Lav kostnad (Sakte, noen ganger blokkert av leverandør)", | ||||
|     "Check octopush prices": "Sjekk octopush priser {0}.", | ||||
|     octopushPhoneNumber: "Telefonnummer (intl format, eg : +4791234567) ", | ||||
|     octopushSMSSender: "SMS Avsendernavn : 3-11 alphanumeriske tegn og mellomrom (a-zA-Z0-9)", | ||||
|     "LunaSea Device ID": "LunaSea Enhet ID", | ||||
|     "Apprise URL": "Apprise URL", | ||||
|     "Example:": "Example: {0}", | ||||
|     "Read more:": "Read more: {0}", | ||||
|     "Example:": "Eksempel: {0}", | ||||
|     "Read more:": "Les mer: {0}", | ||||
|     "Status:": "Status: {0}", | ||||
|     "Read more": "Read more", | ||||
|     appriseInstalled: "Apprise is installed.", | ||||
|     appriseNotInstalled: "Apprise is not installed. {0}", | ||||
|     "Access Token": "Access Token", | ||||
|     "Channel access token": "Channel access token", | ||||
|     "Line Developers Console": "Line Developers Console", | ||||
|     lineDevConsoleTo: "Line Developers Console - {0}", | ||||
|     "Basic Settings": "Basic Settings", | ||||
|     "User ID": "User ID", | ||||
|     "Messaging API": "Messaging API", | ||||
|     wayToGetLineChannelToken: "First access the {0}, create a provider and channel (Messaging API), then you can get the channel access token and user id from the above mentioned menu items.", | ||||
|     "Icon URL": "Icon URL", | ||||
|     aboutIconURL: "You can provide a link to a picture in \"Icon URL\" to override the default profile picture. Will not be used if Icon Emoji is set.", | ||||
|     aboutMattermostChannelName: "You can override the default channel that webhook posts to by entering the channel name into \"Channel Name\" field. This needs to be enabled in Mattermost webhook settings. Ex: #other-channel", | ||||
|     "Read more": "Les mer", | ||||
|     appriseInstalled: "Apprise er installert.", | ||||
|     appriseNotInstalled: "Apprise ikke installert. {0}", | ||||
|     "Access Token": "Tilgangs-Token", | ||||
|     "Channel access token": "Kanal tilgangs-token", | ||||
|     "Line Developers Console": "Line Utviklserskonsoll", | ||||
|     lineDevConsoleTo: "Line Utviklserskonsoll - {0}", | ||||
|     "Basic Settings": "Grunnleggende instillinger", | ||||
|     "User ID": "Bruker-ID", | ||||
|     "Messaging API": "Meldings-API", | ||||
|     wayToGetLineChannelToken: "Først, få tilgang til {0}, lag en leverandør og kanal (Meldings-API),  deretter kan du hente kanaltilgangs-token og bruker id fra menu-valgene nevnt over.", | ||||
|     "Icon URL": "Ikon URL", | ||||
|     aboutIconURL: "Du kan gi en link til et bilde i \"Ikon URL\" for å overskrive det standard profilbildet. Vil ikke bli brukt hvis Ikon Emoji ikke er satt.", | ||||
|     aboutMattermostChannelName: "Du kan overskrive standardkanalen som webhook-en poster i ved å skrive enn kanalnavnet i \"Kanalnavn\" feltet. Dette må være skrudd på i Mattermost webhook-instillingene. Eks: #other-channel", | ||||
|     matrix: "Matrix", | ||||
|     promosmsTypeEco: "SMS ECO - cheap but slow and often overloaded. Limited only to Polish recipients.", | ||||
|     promosmsTypeFlash: "SMS FLASH - Message will automatically show on recipient device. Limited only to Polish recipients.", | ||||
|     promosmsTypeFull: "SMS FULL - Premium tier of SMS, You can use Your Sender Name (You need to register name first). Reliable for alerts.", | ||||
|     promosmsTypeSpeed: "SMS SPEED - Highest priority in system. Very quick and reliable but costly (about twice of SMS FULL price).", | ||||
|     promosmsPhoneNumber: "Phone number (for Polish recipient You can skip area codes)", | ||||
|     promosmsSMSSender: "SMS Sender Name : Pre-registred name or one of defaults: InfoSMS, SMS Info, MaxSMS, INFO, SMS", | ||||
|     promosmsTypeEco: "SMS ECO - billig, men treg og ofte overbelastet. Begrenset til bare polske mottakere.", | ||||
|     promosmsTypeFlash: "SMS FLASH - Melding vil automatisk vises på mottakker-enhet. Begrenset til bare polske mottakere.", | ||||
|     promosmsTypeFull: "SMS FULL - Premuimnivå SMS. Du kan bruke dit avsendernavn (Du må registerere et navn først). Pålitelig for alle varslinger.", | ||||
|     promosmsTypeSpeed: "SMS SPEED - Høyest prioritet i systemet.Veldig rask på pålitelig, men dyrt (omtrent det dobbeltet av SMS FULL pris).", | ||||
|     promosmsPhoneNumber: "Telefonnummber (for polske mottakere. Du trenger ikke områdekode.)", | ||||
|     promosmsSMSSender: "SMS Avsendernavn : Forhåndsregistert navn eller en av standardnavnene: InfoSMS, SMS Info, MaxSMS, INFO, SMS", | ||||
| }; | ||||
|   | ||||
| @@ -12,7 +12,7 @@ export default { | ||||
|     pauseDashboardHome: "Gepauzeerd", | ||||
|     deleteMonitorMsg: "Weet u zeker dat u deze monitor wilt verwijderen?", | ||||
|     deleteNotificationMsg: "Weet u zeker dat u deze melding voor alle monitoren wilt verwijderen?", | ||||
|     resoverserverDescription: "Cloudflare is de standaardserver, u kunt de resolver server op elk moment wijzigen.", | ||||
|     resolverserverDescription: "Cloudflare is de standaardserver, u kunt de resolver server op elk moment wijzigen.", | ||||
|     rrtypeDescription: "Selecteer het RR-type dat u wilt monitoren", | ||||
|     pauseMonitorMsg: "Weet je zeker dat je wilt pauzeren?", | ||||
|     enableDefaultNotificationDescription: "Voor elke nieuwe monitor wordt deze melding standaard ingeschakeld. U kunt de melding nog steeds afzonderlijk uitschakelen voor elke monitor.", | ||||
|   | ||||
| @@ -13,7 +13,7 @@ export default { | ||||
|     pauseDashboardHome: "Wstrzymane", | ||||
|     deleteMonitorMsg: "Czy na pewno chcesz usunąć ten monitor?", | ||||
|     deleteNotificationMsg: "Czy na pewno chcesz usunąć to powiadomienie dla wszystkich monitorów?", | ||||
|     resoverserverDescription: "Cloudflare jest domyślnym serwerem, możesz zmienić serwer resolver w każdej chwili.", | ||||
|     resolverserverDescription: "Cloudflare jest domyślnym serwerem, możesz zmienić serwer resolver w każdej chwili.", | ||||
|     rrtypeDescription: "Wybierz rodzaj rekordu, który chcesz monitorować.", | ||||
|     pauseMonitorMsg: "Czy na pewno chcesz wstrzymać monitorowanie?", | ||||
|     enableDefaultNotificationDescription: "Dla każdego nowego monitora to powiadomienie będzie domyślnie włączone. Nadal możesz wyłączyć powiadomienia osobno dla każdego monitora.", | ||||
| @@ -22,8 +22,8 @@ export default { | ||||
|     confirmClearStatisticsMsg: "Jesteś pewien, że chcesz usunąć WSZYSTKIE statystyki?", | ||||
|     importHandleDescription: "Wybierz 'Pomiń istniejące', jeśli chcesz pominąć każdy monitor lub powiadomienie o tej samej nazwie. 'Nadpisz' spowoduje usunięcie każdego istniejącego monitora i powiadomienia.", | ||||
|     confirmImportMsg: "Czy na pewno chcesz zaimportować kopię zapasową? Upewnij się, że wybrałeś właściwą opcję importu.", | ||||
|     twoFAVerifyLabel: "Proszę podaj swój token 2FA, aby sprawdzić czy 2FA działa.", | ||||
|     tokenValidSettingsMsg: "Token jest prawdiłowy! Teraz możesz zapisać ustawienia 2FA.", | ||||
|     twoFAVerifyLabel: "Proszę, podaj swój token 2FA, aby sprawdzić, czy 2FA działa.", | ||||
|     tokenValidSettingsMsg: "Token jest prawidłowy! Teraz możesz zapisać ustawienia 2FA.", | ||||
|     confirmEnableTwoFAMsg: "Jesteś pewien, że chcesz włączyć 2FA?", | ||||
|     confirmDisableTwoFAMsg: "Jesteś pewien, że chcesz wyłączyć 2FA?", | ||||
|     Settings: "Ustawienia", | ||||
| @@ -68,7 +68,7 @@ export default { | ||||
|     URL: "URL", | ||||
|     Hostname: "Hostname", | ||||
|     Port: "Port", | ||||
|     "Heartbeat Interval": "Czętotliwość bicia serca", | ||||
|     "Heartbeat Interval": "Częstotliwość bicia serca", | ||||
|     Retries: "Prób", | ||||
|     "Heartbeat Retry Interval": "Częstotliwość ponawiania bicia serca", | ||||
|     Advanced: "Zaawansowane", | ||||
| @@ -110,7 +110,7 @@ export default { | ||||
|     "No Monitors, please": "Brak monitorów, proszę", | ||||
|     "add one": "dodać jeden", | ||||
|     "Notification Type": "Rodzaj powiadomienia", | ||||
|     Email: "Email", | ||||
|     Email: "E-mail", | ||||
|     Test: "Test", | ||||
|     "Certificate Info": "Informacje o certyfikacie", | ||||
|     "Resolver Server": "Serwer rozwiązywania nazw", | ||||
| @@ -188,13 +188,13 @@ export default { | ||||
|     "Chat ID": "Identyfikator czatu", | ||||
|     supportTelegramChatID: "Czat wsparcia technicznego / Bezpośrednia rozmowa / Czat grupowy", | ||||
|     wayToGetTelegramChatID: "Możesz uzyskać swój identyfikator czatu, wysyłając wiadomość do bota i przechodząc pod ten adres URL, aby wyświetlić identyfikator czatu:", | ||||
|     "YOUR BOT TOKEN HERE": "TWOJ TOKEN BOTA", | ||||
|     "YOUR BOT TOKEN HERE": "TWÓJ TOKEN BOTA", | ||||
|     chatIDNotFound: "Identyfikator czatu nie znaleziony, najpierw napisz do bota", | ||||
|     webhook: "Webhook", | ||||
|     "Post URL": "Adres URL", | ||||
|     "Content Type": "Rodzaj danych", | ||||
|     webhookJsonDesc: "{0} jest dobry w przypadku serwerów HTTP, takich jak express.js", | ||||
|     webhookFormDataDesc: "{multipart} jest dobry dla PHP, musisz jedynie przetowrzyć dane przez {decodeFunction}", | ||||
|     webhookFormDataDesc: "{multipart} jest dobry dla PHP, musisz jedynie przetworzyć dane przez {decodeFunction}", | ||||
|     smtp: "Email (SMTP)", | ||||
|     secureOptionNone: "Brak / STARTTLS (25, 587)", | ||||
|     secureOptionTLS: "TLS (465)", | ||||
| @@ -205,7 +205,7 @@ export default { | ||||
|     smtpBCC: "UDW", | ||||
|     discord: "Discord", | ||||
|     "Discord Webhook URL": "URL webhook Discorda", | ||||
|     wayToGetDiscordURL: "Możesz go uzyskać przechodząc do Ustawienia serwera -> Integracje -> Tworzenie webhooka", | ||||
|     wayToGetDiscordURL: "Możesz go uzyskać, przechodząc do Ustawienia serwera -> Integracje -> Tworzenie webhooka", | ||||
|     "Bot Display Name": "Wyświetlana nazwa bota", | ||||
|     "Prefix Custom Message": "Własny początek wiadomości", | ||||
|     "Hello @everyone is...": "Hej {'@'}everyone ...", | ||||
| @@ -237,6 +237,7 @@ export default { | ||||
|     promosms: "PromoSMS", | ||||
|     lunasea: "LunaSea", | ||||
|     apprise: "Apprise (obsługuje 50+ usług powiadomień)", | ||||
|     GoogleChat: "Google Chat (wyłącznie Google Workspace)", | ||||
|     pushbullet: "Pushbullet", | ||||
|     line: "Line Messenger", | ||||
|     mattermost: "Mattermost", | ||||
| @@ -259,7 +260,7 @@ export default { | ||||
|     "Read more:": "Czytaj dalej: {0}", | ||||
|     "Status:": "Status: {0}", | ||||
|     "Read more": "Czytaj dalej", | ||||
|     appriseInstalled: "Apprise jest zostało zainstalowane.", | ||||
|     appriseInstalled: "Apprise jest zainstalowane.", | ||||
|     appriseNotInstalled: "Apprise nie zostało zainstalowane. {0}", | ||||
|     "Access Token": "Token dostępu", | ||||
|     "Channel access token": "Token dostępu kanału", | ||||
| @@ -289,7 +290,7 @@ export default { | ||||
|     "Feishu WebHookUrl": "Feishu WebHookURL", | ||||
|     matrixHomeserverURL: "Adres URL serwera domowego (z http(s):// i opcjonalnie port)", | ||||
|     "Internal Room Id": "Wewnętrzne ID pokoju", | ||||
|     matrixDesc1: "Możesz znaleźć wewnętrzne ID pokoju patrząc w zaawansowanej sekcji ustawień pokoju w twoim kliencie Matrix. Powinien on wyglądać jak !QMdRCpUIfLwsfjxye6:home.server.", | ||||
|     matrixDesc1: "Możesz znaleźć wewnętrzne ID pokoju, patrząc w zaawansowanej sekcji ustawień pokoju w twoim kliencie Matrix. Powinien on wyglądać jak !QMdRCpUIfLwsfjxye6:home.server.", | ||||
|     matrixDesc2: "Jest wysoce zalecane, abyś stworzył nowego użytkownika i nie używał tokena dostępu swojego użytkownika Matrix, ponieważ pozwoli on na pełny dostęp do twojego konta i wszystkich pokoi, do których dołączyłeś. Zamiast tego, utwórz nowego użytkownika i zaproś go tylko do pokoju, w którym chcesz otrzymywać powiadomienia. Możesz uzyskać token dostępu przez uruchomienie {0}", | ||||
|     Method: "Metoda", | ||||
|     Body: "Treść", | ||||
| @@ -305,6 +306,44 @@ export default { | ||||
|     steamApiKeyDescription: "Do monitorowania serwera gier Steam potrzebny jest klucz Steam Web-API. Możesz zarejestrować swój klucz API tutaj: ", | ||||
|     "Current User": "Aktualny użytkownik", | ||||
|     recent: "Ostatnie", | ||||
|     Done: "Zrobione", | ||||
|     Info: "Info", | ||||
|     Security: "Bezpieczeństwo", | ||||
|     "Steam API Key": "Klucz Steam API", | ||||
|     "Shrink Database": "Zmniejsz bazę danych", | ||||
|     "Pick a RR-Type...": "Wybierz typ RR...", | ||||
|     "Pick Accepted Status Codes...": "Wybierz akceptowalne kody statusu...", | ||||
|     Default: "Domyślnie", | ||||
|     "HTTP Options": "Opcje HTTP", | ||||
|     "Create Incident": "Stwórz incydent", | ||||
|     Title: "Tytuł", | ||||
|     Content: "Treść", | ||||
|     Style: "Styl", | ||||
|     info: "info", | ||||
|     warning: "ostrzeżenie", | ||||
|     danger: "niebezpieczeństwo", | ||||
|     primary: "podstawowy", | ||||
|     light: "jasny", | ||||
|     dark: "ciemny", | ||||
|     Post: "Wyślij", | ||||
|     "Please input title and content": "Podaj tytuł i treść", | ||||
|     Created: "Stworzony", | ||||
|     "Last Updated": "Ostatnio zaktualizowany", | ||||
|     Unpin: "Odepnij", | ||||
|     "Switch to Light Theme": "Przełącz na jasny motyw", | ||||
|     "Switch to Dark Theme": "Przełącz na ciemny motyw", | ||||
|     "Show Tags": "Pokaż tagi", | ||||
|     "Hide Tags": "Ukryj tagi", | ||||
|     Description: "Opis", | ||||
|     "No monitors available.": "Brak dostępnych monitorów.", | ||||
|     "Add one": "Dodaj jeden", | ||||
|     "No Monitors": "Brak monitorów", | ||||
|     "Untitled Group": "Nienazwana grupa", | ||||
|     Services: "Usługi", | ||||
|     Discard: "Odrzuć", | ||||
|     Cancel: "Anuluj", | ||||
|     "Powered by": "Napędzane przez", | ||||
|     shrinkDatabaseDescription: "Uruchom VACUUM na bazie SQLite. Jeżeli twoja baza została stworzona po wersji 1.10.0, to posiada już włączoną opcję AUTO_VACUUM i stosowanie ręcznego oczyszczania nie jest potrzebne.", | ||||
|     clicksendsms: "ClickSend SMS", | ||||
|     apiCredentials: "Poświadczenia API", | ||||
|     serwersms: "SerwerSMS.pl", | ||||
| @@ -312,4 +351,14 @@ export default { | ||||
|     serwersmsAPIPassword: "Hasło API", | ||||
|     serwersmsPhoneNumber: "Numer telefonu", | ||||
|     serwersmsSenderName: "Nazwa nadawcy (zatwierdzona w panelu klienta)", | ||||
|     "stackfield": "Stackfield", | ||||
|     smtpDkimSettings: "Ustawienia DKIM", | ||||
|     smtpDkimDesc: "Zapoznaj się z Nodemailer DKIM {0}, aby dowiedzieć się więcej", | ||||
|     documentation: "dokumentacja", | ||||
|     smtpDkimDomain: "Nazwa domeny", | ||||
|     smtpDkimKeySelector: "Selektor klucza", | ||||
|     smtpDkimPrivateKey: "Klucz prywatny", | ||||
|     smtpDkimHashAlgo: "Algorytm Hashowania (opcjonalne)", | ||||
|     smtpDkimheaderFieldNames: "Klucze nagłówka do podpisu (opcjonalne)", | ||||
|     smtpDkimskipFields: "Klucze nagłówka do pominięcia (opcjonalne)", | ||||
| }; | ||||
|   | ||||
| @@ -13,7 +13,7 @@ export default { | ||||
|     pauseDashboardHome: "Pausar", | ||||
|     deleteMonitorMsg: "Tem certeza de que deseja excluir este monitor?", | ||||
|     deleteNotificationMsg: "Tem certeza de que deseja excluir esta notificação para todos os monitores?", | ||||
|     resoverserverDescription: "Cloudflare é o servidor padrão, você pode alterar o servidor resolvedor a qualquer momento.", | ||||
|     resolverserverDescription: "Cloudflare é o servidor padrão, você pode alterar o servidor resolvedor a qualquer momento.", | ||||
|     rrtypeDescription: "Selecione o RR-Type que você deseja monitorar", | ||||
|     pauseMonitorMsg: "Tem certeza que deseja fazer uma pausa?", | ||||
|     enableDefaultNotificationDescription: "Para cada novo monitor, esta notificação será habilitada por padrão. Você ainda pode desativar a notificação separadamente para cada monitor.", | ||||
|   | ||||
| @@ -12,11 +12,11 @@ export default { | ||||
|     pauseDashboardHome: "Пауза", | ||||
|     deleteMonitorMsg: "Вы действительно хотите удалить данный монитор?", | ||||
|     deleteNotificationMsg: "Вы действительно хотите удалить это уведомление для всех мониторов?", | ||||
|     resoverserverDescription: "Cloudflare является сервером по умолчанию. Вы всегда можете сменить данный сервер.", | ||||
|     resolverserverDescription: "Cloudflare является сервером по умолчанию. Вы всегда можете сменить данный сервер.", | ||||
|     rrtypeDescription: "Выберите тип ресурсной записи, который вы хотите отслеживать", | ||||
|     pauseMonitorMsg: "Вы действительно хотите поставить на паузу?", | ||||
|     Settings: "Настройки", | ||||
|     Dashboard: "Панель мониторов", | ||||
|     Dashboard: "Панель управления", | ||||
|     "New Update": "Обновление", | ||||
|     Language: "Язык", | ||||
|     Appearance: "Внешний вид", | ||||
| @@ -60,7 +60,7 @@ export default { | ||||
|     "Heartbeat Interval": "Частота опроса", | ||||
|     Retries: "Попыток", | ||||
|     Advanced: "Дополнительно", | ||||
|     "Upside Down Mode": "Режим реверса статуса", | ||||
|     "Upside Down Mode": "Реверс статуса", | ||||
|     "Max. Redirects": "Макс. количество перенаправлений", | ||||
|     "Accepted Status Codes": "Допустимые коды статуса", | ||||
|     Save: "Сохранить", | ||||
| @@ -75,9 +75,9 @@ export default { | ||||
|     Bottom: "Снизу", | ||||
|     None: "Отсутствует", | ||||
|     Timezone: "Часовой пояс", | ||||
|     "Search Engine Visibility": "Видимость поисковым движком", | ||||
|     "Search Engine Visibility": "Индексация поисковыми системами:", | ||||
|     "Allow indexing": "Разрешить индексирование", | ||||
|     "Discourage search engines from indexing site": "Не позволять индексировать сайт", | ||||
|     "Discourage search engines from indexing site": "Запретить индексирование", | ||||
|     "Change Password": "Сменить пароль", | ||||
|     "Current Password": "Текущий пароль", | ||||
|     "New Password": "Новый пароль", | ||||
| @@ -96,6 +96,7 @@ export default { | ||||
|     "Remember me": "Запомнить меня", | ||||
|     Login: "Вход в систему", | ||||
|     "No Monitors, please": "Мониторов нет, пожалуйста", | ||||
|     "No Monitors": "Мониторы отсутствуют", | ||||
|     "add one": "создайте новый", | ||||
|     "Notification Type": "Тип уведомления", | ||||
|     Email: "Почта", | ||||
| @@ -107,7 +108,7 @@ export default { | ||||
|     "Create your admin account": "Создайте аккаунт администратора", | ||||
|     "Repeat Password": "Повторите пароль", | ||||
|     respTime: "Время ответа (мс)", | ||||
|     notAvailableShort: "Н/Д", | ||||
|     notAvailableShort: "N/A", | ||||
|     Create: "Создать", | ||||
|     clearEventsMsg: "Вы действительно хотите удалить всю статистику событий данного монитора?", | ||||
|     clearHeartbeatsMsg: "Вы действительно хотите удалить всю статистику опросов данного монитора?", | ||||
| @@ -119,8 +120,8 @@ export default { | ||||
|     enableDefaultNotificationDescription: "Для каждого нового монитора это уведомление будет включено по умолчанию. Вы всё ещё можете отключить уведомления в каждом мониторе отдельно.", | ||||
|     "Default enabled": "Использовать по умолчанию", | ||||
|     "Also apply to existing monitors": "Применить к существующим мониторам", | ||||
|     Export: "Резервная копия", | ||||
|     Import: "Восстановление", | ||||
|     Export: "Экспорт", | ||||
|     Import: "Импорт", | ||||
|     backupDescription: "Вы можете сохранить резервную копию всех мониторов и уведомлений в виде JSON-файла", | ||||
|     backupDescription2: "P.S. История и события сохранены не будут", | ||||
|     backupDescription3: "Важные данные, такие как токены уведомлений, добавляются при экспорте, поэтому храните файлы в безопасном месте", | ||||
| @@ -141,13 +142,13 @@ export default { | ||||
|     Inactive: "Неактивно", | ||||
|     Token: "Токен", | ||||
|     "Show URI": "Показать URI", | ||||
|     "Clear all statistics": "Удалить всю статистику", | ||||
|     "Clear all statistics": "Очистить статистику", | ||||
|     retryCheckEverySecond: "Повтор каждые {0} секунд", | ||||
|     importHandleDescription: "Выберите \"Пропустить существующие\", если вы хотите пропустить каждый монитор или уведомление с таким же именем. \"Перезаписать\" удалит каждый существующий монитор или уведомление и добавит заново. Вариант \"Не проверять\" принудительно восстанавливает все мониторы и уведомления, даже если они уже существуют.", | ||||
|     confirmImportMsg: "Вы действительно хотите восстановить резервную копию? Убедитесь, что вы выбрали подходящий вариант импорта.", | ||||
|     "Heartbeat Retry Interval": "Интервал повтора опроса", | ||||
|     "Import Backup": "Восстановление резервной копии", | ||||
|     "Export Backup": "Резервная копия", | ||||
|     "Import Backup": "Импорт", | ||||
|     "Export Backup": "Скачать", | ||||
|     "Skip existing": "Пропустить существующие", | ||||
|     Overwrite: "Перезаписать", | ||||
|     Options: "Опции", | ||||
| @@ -167,19 +168,19 @@ export default { | ||||
|     Purple: "Пурпурный", | ||||
|     Pink: "Розовый", | ||||
|     "Search...": "Поиск...", | ||||
|     "Avg. Ping": "Средн. пинг", | ||||
|     "Avg. Response": "Средн. ответ", | ||||
|     "Avg. Ping": "Среднее значение пинга", | ||||
|     "Avg. Response": "Среднее время ответа", | ||||
|     "Entry Page": "Главная страница", | ||||
|     statusPageNothing: "Здесь пусто. Добавьте группу или монитор.", | ||||
|     "No Services": "Нет сервисов", | ||||
|     "All Systems Operational": "Все сервисы работают", | ||||
|     "Partially Degraded Service": "Сервисы частично не работают", | ||||
|     "All Systems Operational": "Все системы работают в штатном режиме", | ||||
|     "Partially Degraded Service": "Сервисы работают частично", | ||||
|     "Degraded Service": "Все сервисы не работают", | ||||
|     "Add Group": "Добавить группу", | ||||
|     "Add a monitor": "Добавить монитор", | ||||
|     "Edit Status Page": "Редактировать", | ||||
|     "Go to Dashboard": "Панель мониторов", | ||||
|     "Status Page": "Статус сервисов", | ||||
|     "Go to Dashboard": "Панель управления", | ||||
|     "Status Page": "Мониторинг", | ||||
|     Discard: "Отмена", | ||||
|     "Create Incident": "Создать инцидент", | ||||
|     "Switch to Dark Theme": "Тёмная тема", | ||||
| @@ -302,10 +303,35 @@ export default { | ||||
|     PushUrl: "URL пуша", | ||||
|     HeadersInvalidFormat: "Заголовки запроса некорректны JSON: ", | ||||
|     BodyInvalidFormat: "Тело запроса некорректно JSON: ", | ||||
|     "Monitor History": "История мониторов", | ||||
|     clearDataOlderThan: "Сохранять историю мониторов в течение {0} дней.", | ||||
|     "Monitor History": "Статистика", | ||||
|     clearDataOlderThan: "Сохранять статистику за {0} дней.", | ||||
|     PasswordsDoNotMatch: "Пароли не совпадают.", | ||||
|     records: "записей", | ||||
|     "One record": "Одна запись", | ||||
|     steamApiKeyDescription: "Для мониторинга игрового сервера Steam вам необходим Web-API ключ Steam. Зарегистрировать его можно здесь: ", | ||||
|     "Certificate Chain": "Цепочка сертификатов", | ||||
|     "Valid": "Действительный", | ||||
|     "Hide Tags": "Скрыть тэги", | ||||
|     "Title": "Название инцидента:", | ||||
|     "Content": "Содержание инцидента:", | ||||
|     "Post": "Опубликовать", | ||||
|     "Cancel": "Отмена", | ||||
|     "Created": "Создано", | ||||
|     "Unpin": "Открепить", | ||||
|     "Show Tags": "Показать тэги", | ||||
|     "recent": "Сейчас", | ||||
|     "3h": "3 часа", | ||||
|     "6h": "6 часов", | ||||
|     "24h": "24 часа", | ||||
|     "1w": "1 неделя", | ||||
|     "No monitors available.": "Нет доступных мониторов", | ||||
|     "Add one": "Добавить новый", | ||||
|     "Backup": "Резервная копия", | ||||
|     "Security": "Безопасность", | ||||
|     "Shrink Database": "Сжать Базу Данных", | ||||
|     "Current User": "Текущий пользователь", | ||||
|     "About": "О программе", | ||||
|     "Description": "Описание", | ||||
|     "Powered by": "Работает на основе скрипта от", | ||||
|     shrinkDatabaseDescription: "Включает VACUUM для базы данных SQLite. Если ваша база данных была создана на версии 1.10.0 и более, AUTO_VACUUM уже включен и это действие не требуется.", | ||||
| }; | ||||
|   | ||||
							
								
								
									
										354
									
								
								src/languages/sl-SI.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										354
									
								
								src/languages/sl-SI.js
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,354 @@ | ||||
| export default { | ||||
|     languageName: "Slovenščina", | ||||
|     checkEverySecond: "Preveri na vsakih {0} sekund", | ||||
|     retryCheckEverySecond: "Ponovno poskusi na vsakih {0} sekund", | ||||
|     retriesDescription: "Maksimalno število poskusov predenj se storitev označi kot 'ne deluje' in se pošlje obvestilo", | ||||
|     ignoreTLSError: "Ignoriraj TLS/SSL napake za HTTPS spletne strani", | ||||
|     upsideDownModeDescription: "Negiraj status. Če je storitev deluje bo označena kot 'ne deluje'.", | ||||
|     maxRedirectDescription: "Maksimalno število sledečih preusmeritev. 0 onemogoči preusmeritve.", | ||||
|     acceptedStatusCodesDescription: "Izberi kode statusa veljavna kot uspešen odgovor.", | ||||
|     passwordNotMatchMsg: "Ponovljeno geslo se ne ujema.", | ||||
|     notificationDescription: "Obvestila morajo biti dodeljena monitorju, da delujejo.", | ||||
|     keywordDescription: "Iskana ključna beseda v surovem HTML ali JSON odgovoru. Iskanje je občutljivo na začetnico.", | ||||
|     pauseDashboardHome: "Pavza", | ||||
|     deleteMonitorMsg: "Ste prepričani, da želite izbrisati ta monitor?", | ||||
|     deleteNotificationMsg: "Ste prepričani, da želite izbrisati to obvestilo za vse monitorje?", | ||||
|     resolverserverDescription: "Cloudflare je privzeti strežnik. DNS strežnik lahko spremenite kadarkoli.", | ||||
|     rrtypeDescription: "Izberite RR tip, ki ga želite spremljati", | ||||
|     pauseMonitorMsg: "Ste prepričani, da želite pavzirati?", | ||||
|     enableDefaultNotificationDescription: "To obvestilo bo kot privzeto omogočeno za vse nove monitorje. Še vedno ga lahko izključite posebej za vsak monitor.", | ||||
|     clearEventsMsg: "Ste prepričani da želite izbrisati vse dogodke tega monitorja?", | ||||
|     clearHeartbeatsMsg: "Ste prepričani da želite izbrisati vse srčne utripe tega monitorja?", | ||||
|     confirmClearStatisticsMsg: "Ste prepričani da želite izbrisati VSO statistiko?", | ||||
|     importHandleDescription: "Izberite 'Preskoči obstoječe', če želite preskočiti vsak monitor ali obvestilo z istim imenom. 'Prepiši' bo prepisal vse obstoječe monitorje in obvestila.", | ||||
|     confirmImportMsg: "Ste prepričani da želite uvoziti varnostno kopijo? Preverite da ste izbrali pravo opcijo za uvoz.", | ||||
|     twoFAVerifyLabel: "Prosimo vnesite žeton za potrditev 2FA:", | ||||
|     tokenValidSettingsMsg: "Žeton je veljaven! Sedaj lahko shranite 2FA nastavitev.", | ||||
|     confirmEnableTwoFAMsg: "Ste prepričani, da želite omogočiti 2FA?", | ||||
|     confirmDisableTwoFAMsg: "Ste prepričani, da želite onemogočiti 2FA?", | ||||
|     Settings: "Nastavitve", | ||||
|     Dashboard: "Nadzorna plošča", | ||||
|     "New Update": "Nova posodobitev", | ||||
|     Language: "Jezik", | ||||
|     Appearance: "Izgled", | ||||
|     Theme: "Teme", | ||||
|     General: "Splošno", | ||||
|     "Primary Base URL": "Primaren URL", | ||||
|     Version: "Različica", | ||||
|     "Check Update On GitHub": "Preveri posodobitev na GitHub-u", | ||||
|     List: "Seznam", | ||||
|     Add: "Dodaj", | ||||
|     "Add New Monitor": "Dodaj nov monitor", | ||||
|     "Quick Stats": "Hitro stanje", | ||||
|     Up: "Deluje", | ||||
|     Down: "Ne deluje", | ||||
|     Pending: "Na čakanju", | ||||
|     Unknown: "Neznano", | ||||
|     Pause: "Pavza", | ||||
|     Name: "Ime", | ||||
|     Status: "Status", | ||||
|     DateTime: "DateTime", | ||||
|     Message: "Sporočilo", | ||||
|     "No important events": "Ni pomembnih dogodkov", | ||||
|     Resume: "Nadaljuj", | ||||
|     Edit: "Uredi", | ||||
|     Delete: "Izbriši", | ||||
|     Current: "Trenutno", | ||||
|     Uptime: "Uptime", | ||||
|     "Cert Exp.": "Potek certifikata", | ||||
|     days: "dni", | ||||
|     day: "dan", | ||||
|     "-day": "-dni", | ||||
|     hour: "ura", | ||||
|     "-hour": "-ur", | ||||
|     Response: "Odgovor", | ||||
|     Ping: "Ping", | ||||
|     "Monitor Type": "Tip monitorja", | ||||
|     Keyword: "Ključna beseda", | ||||
|     "Friendly Name": "Ime za prikaz", | ||||
|     URL: "URL", | ||||
|     Hostname: "Hostname", | ||||
|     Port: "Vrata", | ||||
|     "Heartbeat Interval": "Interval srčnega utripa", | ||||
|     Retries: "Ponovni poskusi", | ||||
|     "Heartbeat Retry Interval": "Ponovni poskus srčnega utripa", | ||||
|     Advanced: "Napredno", | ||||
|     "Upside Down Mode": "Negiran način", | ||||
|     "Max. Redirects": "Max. preusmeritev", | ||||
|     "Accepted Status Codes": "Sprejete kode statusa", | ||||
|     "Push URL": "Push URL", | ||||
|     needPushEvery: "Pokliči ta URL vsakih {0} sekund.", | ||||
|     pushOptionalParams: "Dodatni parametri: {0}", | ||||
|     Save: "Shrani", | ||||
|     Notifications: "Obvestila", | ||||
|     "Not available, please setup.": "Ni na voljo, prosimo nastavite.", | ||||
|     "Setup Notification": "Nastavi obvestila", | ||||
|     Light: "Svetlo", | ||||
|     Dark: "Temno", | ||||
|     Auto: "Auto", | ||||
|     "Theme - Heartbeat Bar": "Tema - vrstica srčnega utripa", | ||||
|     Normal: "Normalna", | ||||
|     Bottom: "Spodaj", | ||||
|     None: "Brez", | ||||
|     Timezone: "Časovni pas", | ||||
|     "Search Engine Visibility": "Vidljivost v spletnih iskalnikih", | ||||
|     "Allow indexing": "Dovoli indeksiranje", | ||||
|     "Discourage search engines from indexing site": "Odvračaj spletne iskalnike od indeksiranja te strani", | ||||
|     "Change Password": "Zamenjaj geslo", | ||||
|     "Current Password": "Trenutno geslo", | ||||
|     "New Password": "Novo geslo", | ||||
|     "Repeat New Password": "Ponovi novo geslo", | ||||
|     "Update Password": "Posodobi geslo", | ||||
|     "Disable Auth": "Onemogoči auth", | ||||
|     "Enable Auth": "Omogoči auth", | ||||
|     Logout: "Odjava", | ||||
|     Leave: "Zapusti", | ||||
|     "I understand, please disable": "Razumem, prosim onemogočite", | ||||
|     Confirm: "Potrdi", | ||||
|     Yes: "Da", | ||||
|     No: "Ne", | ||||
|     Username: "Uporabniško ime", | ||||
|     Password: "Geslo", | ||||
|     "Remember me": "Zapomni si me", | ||||
|     Login: "Vpis", | ||||
|     "No Monitors, please": "Prosim, brez monitorjev", | ||||
|     "add one": "Dodaj enega", | ||||
|     "Notification Type": "Tip obvestila", | ||||
|     Email: "Email", | ||||
|     Test: "Test", | ||||
|     "Certificate Info": "Informacije certifikata", | ||||
|     "Resolver Server": "Strežnik za razreševanje", | ||||
|     "Resource Record Type": "Vrsta zapisa o viru", | ||||
|     "Last Result": "Zadnji rezultat", | ||||
|     "Create your admin account": "Ustvari administratorski račun", | ||||
|     "Repeat Password": "Ponovi geslo", | ||||
|     "Import Backup": "Uvozi varnostno kopijo", | ||||
|     "Export Backup": "Izvozi varnostno kopijo", | ||||
|     Export: "Izvozi", | ||||
|     Import: "Uvozi", | ||||
|     respTime: "Odzivni čas (ms)", | ||||
|     notAvailableShort: "N/A", | ||||
|     "Default enabled": "Privzeto omogočeno", | ||||
|     "Apply on all existing monitors": "Uporabi na vseh obstoječih monitorjih", | ||||
|     Create: "Ustvari", | ||||
|     "Clear Data": "Izbriši podatke", | ||||
|     Events: "Dogodki", | ||||
|     Heartbeats: "Srčni utripi", | ||||
|     "Auto Get": "Auto Get", | ||||
|     backupDescription: "Izvozite lahko vse monitorje in obvestila v JSON datoteko.", | ||||
|     backupDescription2: "Pomni: Zgodovina in podatki dogodkov niso vključeni.", | ||||
|     backupDescription3: "Občutljivi podatki, kot žetoni za obvestila so vlkjučeni v datoteko za izvoz; prosimo hranite na varnem.", | ||||
|     alertNoFile: "Izberite datoteko za Uvoz.", | ||||
|     alertWrongFileType: "Prosimo izberite JSON datoteko.", | ||||
|     "Clear all statistics": "Pobrišite vso statistiko", | ||||
|     "Skip existing": "Preskoči obstoječe", | ||||
|     Overwrite: "Prepiši", | ||||
|     Options: "Možnosti", | ||||
|     "Keep both": "Ohrani oboje", | ||||
|     "Verify Token": "Potrdi žeton", | ||||
|     "Setup 2FA": "Nastavi 2FA", | ||||
|     "Enable 2FA": "Omogoči 2FA", | ||||
|     "Disable 2FA": "Onemogoči 2FA", | ||||
|     "2FA Settings": "2FA nastavitve", | ||||
|     "Two Factor Authentication": "Preverjanje pristnosti z dvema dejavnikoma", | ||||
|     Active: "Aktivno", | ||||
|     Inactive: "Neaktivno", | ||||
|     Token: "Žeton", | ||||
|     "Show URI": "Prikaži URI", | ||||
|     Tags: "Značke", | ||||
|     "Add New below or Select...": "Dodaj novo spodaj ali izberi iz seznama...", | ||||
|     "Tag with this name already exist.": "Značka s tem imenom že obstaja.", | ||||
|     "Tag with this value already exist.": "Značka s to vrednostjo že obstaja.", | ||||
|     color: "barva", | ||||
|     "value (optional)": "vrednost (po želji)", | ||||
|     Gray: "Siva", | ||||
|     Red: "Rdeča", | ||||
|     Orange: "Oranžna", | ||||
|     Green: "Zelena", | ||||
|     Blue: "Modra", | ||||
|     Indigo: "Indigo", | ||||
|     Purple: "Vijolična", | ||||
|     Pink: "Roza", | ||||
|     "Search...": "Išči...", | ||||
|     "Avg. Ping": "Avg. Ping", | ||||
|     "Avg. Response": "Avg. odziv", | ||||
|     "Entry Page": "Vstopna stran", | ||||
|     statusPageNothing: "Nikjer nič... Dodajte skupino ali monitor.", | ||||
|     "No Services": "Ni storitev", | ||||
|     "All Systems Operational": "Vsi sistemi delujejo", | ||||
|     "Partially Degraded Service": "Delno poslabšana storitev", | ||||
|     "Degraded Service": "Poslabšana storitev", | ||||
|     "Add Group": "Dodaj skupino", | ||||
|     "Add a monitor": "Dodaj monitor", | ||||
|     "Edit Status Page": "Uredi statusno stran", | ||||
|     "Go to Dashboard": "Pojdi na nadzorno ploščo", | ||||
|     "Status Page": "Status", | ||||
|     defaultNotificationName: "Moje {notification} Obvestilo ({number})", | ||||
|     here: "tukaj", | ||||
|     Required: "Obvezno", | ||||
|     telegram: "Telegram", | ||||
|     "Bot Token": "Robotkov žetonček", | ||||
|     wayToGetTelegramToken: "Lahko dobiš žeton od {0}.", | ||||
|     "Chat ID": "ID pogovora", | ||||
|     supportTelegramChatID: "Direkten pogovor pomoči / Skupina / ID kanala", | ||||
|     wayToGetTelegramChatID: "Id lahko dobiš, če pošlješ sporočilo robotku in odpreš ta URL, da bi videl chat_id:", | ||||
|     "YOUR BOT TOKEN HERE": "ROBOTKOV ŽETON TUKAJ", | ||||
|     chatIDNotFound: "Ne najdem Chat Id-ja; prvo pošlji sporočilo robotku", | ||||
|     webhook: "Webhook", | ||||
|     "Post URL": "Post URL", | ||||
|     "Content Type": "Vrsta vsebine", | ||||
|     webhookJsonDesc: "{0} je v redu za vsak moderen HTTP strežnik, kot recimo Express.js", | ||||
|     webhookFormDataDesc: "{multipart} je v redu za PHP. JSON bo moral biti razčlenjen s {decodeFunction}", | ||||
|     smtp: "Email (SMTP)", | ||||
|     secureOptionNone: "Brez / STARTTLS (25, 587)", | ||||
|     secureOptionTLS: "TLS (465)", | ||||
|     "Ignore TLS Error": "Ignoriraj TLS napako", | ||||
|     "From Email": "Od Email", | ||||
|     emailCustomSubject: "Poljubna zadeva", | ||||
|     "To Email": "Za Email", | ||||
|     smtpCC: "CC", | ||||
|     smtpBCC: "BCC", | ||||
|     discord: "Discord", | ||||
|     "Discord Webhook URL": "Discord Webhook URL", | ||||
|     wayToGetDiscordURL: "To lahko dibiš v Server Settings -> Integrations -> Create Webhook", | ||||
|     "Bot Display Name": "Prikazno ime robotka", | ||||
|     "Prefix Custom Message": "Predpona poljubnega sporočila", | ||||
|     "Hello @everyone is...": "Pozdravljen {'@'}everyone je...", | ||||
|     teams: "Microsoft Teams", | ||||
|     "Webhook URL": "Webhook URL", | ||||
|     wayToGetTeamsURL: "Izvedi kako narediš webhook URL {0}.", | ||||
|     signal: "Signal", | ||||
|     Number: "Številka", | ||||
|     Recipients: "Prejemniki", | ||||
|     needSignalAPI: "Imeti moraš signal klienta z REST API.", | ||||
|     wayToCheckSignalURL: "Kako se to naredi, lahko preveriš na tem URL-ju:", | ||||
|     signalImportant: "POMEMBNO: Ne moreš mešati skupin in številk v prejemnikih!", | ||||
|     gotify: "Gotify", | ||||
|     "Application Token": "Žeton za aplikacijo", | ||||
|     "Server URL": "URL Strežnika", | ||||
|     Priority: "Prioriteta", | ||||
|     slack: "Slack", | ||||
|     "Icon Emoji": "Emoji ikona", | ||||
|     "Channel Name": "Ime kanala", | ||||
|     "Uptime Kuma URL": "Uptime Kuma URL", | ||||
|     aboutWebhooks: "Več o webhook-ih: {0}", | ||||
|     aboutChannelName: "Vnesi ime kanala na {0} Channel Name polje, če želiš preskočiti webhook kanal. npr.: #drug-kanal", | ||||
|     aboutKumaURL: "Če pustite polje Uptime Kuma URL prazno, bo nastavljeno privzeto na GitHub stran projekta.", | ||||
|     emojiCheatSheet: "Emoji plonk listek: {0}", | ||||
|     "rocket.chat": "Rocket.Chat", | ||||
|     pushover: "Pushover", | ||||
|     pushy: "Pushy", | ||||
|     octopush: "Octopush", | ||||
|     promosms: "PromoSMS", | ||||
|     clicksendsms: "ClickSend SMS", | ||||
|     lunasea: "LunaSea", | ||||
|     apprise: "Apprise (podpira 50+ storitev za obveščevanje)", | ||||
|     pushbullet: "Pushbullet", | ||||
|     line: "Line Messenger", | ||||
|     mattermost: "Mattermost", | ||||
|     "User Key": "User Key", | ||||
|     Device: "Naprava", | ||||
|     "Message Title": "Naslov sporočila", | ||||
|     "Notification Sound": "Zvok obvestila", | ||||
|     "More info on:": "Več informacij na: {0}", | ||||
|     pushoverDesc1: "Prioriteta nujnosti (2) ima privzeto nastavitev 30 sekund časa med ponovni poskusi in poteče po 1 uri.", | ||||
|     pushoverDesc2: "Če želite pošiljati obvestila na različne naprave izpolnite polje 'Naprava'.", | ||||
|     "SMS Type": "Vrsta SMS-a", | ||||
|     octopushTypePremium: "Premium (hitro - priporočljivo za opozarjanje)", | ||||
|     octopushTypeLowCost: "Cenovno ugodno (počasno - včasih jih blokira operater)", | ||||
|     checkPrice: "preveri {0} cene:", | ||||
|     apiCredentials: "API poverilnice", | ||||
|     octopushLegacyHint: "Uporabljate legacy verzijo Octopush-a (2011-2020) ali novo verzijo?", | ||||
|     "Check octopush prices": "Preveri octopush cene {0}.", | ||||
|     octopushPhoneNumber: "Telefonska številka (npr.: +386031234567) ", | ||||
|     octopushSMSSender: "Ime SMS pošiljatelja: 3-11 alfanumeričnih znakov in presledki (a-zA-Z0-9)", | ||||
|     "LunaSea Device ID": "LunaSea Device ID", | ||||
|     "Apprise URL": "Apprise URL", | ||||
|     "Example:": "Primer: {0}", | ||||
|     "Read more:": "Preberi več: {0}", | ||||
|     "Status:": "Status: {0}", | ||||
|     "Read more": "Preberi več", | ||||
|     appriseInstalled: "Apprise je nameščen.", | ||||
|     appriseNotInstalled: "Apprise ni nameščen. {0}", | ||||
|     "Access Token": "Žeton za dostop", | ||||
|     "Channel access token": "Žeton za dostop do kanala", | ||||
|     "Line Developers Console": "Line Developers Console", | ||||
|     lineDevConsoleTo: "Line Developers Console - {0}", | ||||
|     "Basic Settings": "Osnovne nastavitve", | ||||
|     "User ID": "User ID", | ||||
|     "Messaging API": "Messaging API", | ||||
|     wayToGetLineChannelToken: "Prvo odpri {0}, ustvarite ponudnika in kanal (Messaging API), potem lahko žeton za dostop do kanala in ID uporabnika dobite iz zgoraj navedenih elementov menija.", | ||||
|     "Icon URL": "URL ikone", | ||||
|     aboutIconURL: "V razdelku \"URL ikone\" lahko zagotovite povezavo do slike, ki bo nadomestila privzeto sliko profila. Ne bo uporabljena, če je nastavljena ikona Emoji.", | ||||
|     aboutMattermostChannelName: "V razdelku \"URL ikone\" lahko zagotovite povezavo do slike, ki bo nadomestila privzeto sliko profila. Ne bo uporabljena, če je nastavljena ikona Emoji", | ||||
|     matrix: "Matrix", | ||||
|     promosmsTypeEco: "SMS ECO - poceni, vendar počasen in pogosto preobremenjen. Omejeno samo na poljske prejemnike.", | ||||
|     promosmsTypeFlash: "SMS FLASH - sporočilo se samodejno prikaže v napravi prejemnika. Omejeno samo na poljske prejemnike.", | ||||
|     promosmsTypeFull: "SMS FULL - Premium raven SMS, Uporabite lahko svoje ime pošiljatelja (najprej morate registrirati ime). Zanesljivo za opozorila.", | ||||
|     promosmsTypeSpeed: "SMS SPEED - Najvišja prednost v sistemu. Zelo hitro in zanesljivo, vendar drago (približno dvakratnik cene SMS FULL)..", | ||||
|     promosmsPhoneNumber: "Telefonska številka (za poljskega prejemnika Lahko preskočite področne oznake", | ||||
|     promosmsSMSSender: "Ime pošiljatelja SMS : vnaprej registrirano ime ali eno od privzetih: SMS, SMS Info, MaxSMS, INFO, SMS", | ||||
|     "Feishu WebHookUrl": "Feishu WebHookURL", | ||||
|     matrixHomeserverURL: "Homeserver URL (z http(s):// in vrata po želji)", | ||||
|     "Internal Room Id": "Interni ID sobe", | ||||
|     matrixDesc1: "Notranji ID sobe lahko poiščete v naprednem razdelku nastavitev sobe v odjemalcu Matrix. Izgledati mora kot !QMdRCpUIfLwsfjxye6:home.server", | ||||
|     matrixDesc2: "Zelo priporočljivo je, da ustvarite novega uporabnika in ne uporabljate svojega žetona za dostop uporabnika Matrix, saj bo omogočil popoln dostop do vašega računa in vseh sob, ki ste se jim pridružili. Namesto tega ustvarite novega uporabnika in ga povabite le v sobo, v kateri želite prejemati obvestila. Token dostopa lahko dobite tako, da zaženete {0}", | ||||
|     Method: "Metoda", | ||||
|     Body: "Telo", | ||||
|     Headers: "Glave", | ||||
|     PushUrl: "Push URL", | ||||
|     HeadersInvalidFormat: "Glave zahtevka niso veljavni JSON: ", | ||||
|     BodyInvalidFormat: "Telo zahteve ni veljaven JSON: ", | ||||
|     "Monitor History": "Zgodovina", | ||||
|     clearDataOlderThan: "Ohrani zgodovino {0} dni.", | ||||
|     PasswordsDoNotMatch: "Gesli se ne ujemata.", | ||||
|     records: "vnosi", | ||||
|     "One record": "En vnos", | ||||
|     steamApiKeyDescription: "Za spremljanje igralnega strežnika Steam potrebujete ključ spletnega vmesnika Steam. Ključ API lahko registrirate tukaj: ", | ||||
|     "Current User": "Trenuten uporabnik", | ||||
|     recent: "Nedavno", | ||||
|     Done: "Zaključi", | ||||
|     Info: "Info", | ||||
|     Security: "Varnost", | ||||
|     "Steam API Key": "Steam API Key", | ||||
|     "Shrink Database": "Stisni bazo", | ||||
|     "Pick a RR-Type...": "Izberi RR tip...", | ||||
|     "Pick Accepted Status Codes...": "Izbiranje sprejetih kod stanja...", | ||||
|     Default: "Privzeto", | ||||
|     "HTTP Options": "HTTP možnosti", | ||||
|     "Create Incident": "Ustvari incident", | ||||
|     Title: "Naslov", | ||||
|     Content: "Vsebina", | ||||
|     Style: "Stil", | ||||
|     info: "info", | ||||
|     warning: "opozorilo", | ||||
|     danger: "nevarnost", | ||||
|     primary: "primarno", | ||||
|     light: "svetlo", | ||||
|     dark: "temno", | ||||
|     Post: "Objavi", | ||||
|     "Please input title and content": "Vnesi naslov in vsebino", | ||||
|     Created: "Ustvarjeno", | ||||
|     "Last Updated": "Nazadnje posodobljeno", | ||||
|     Unpin: "Odpni", | ||||
|     "Switch to Light Theme": "Preklopi na svetlo temo", | ||||
|     "Switch to Dark Theme": "Preklopi na temno temo", | ||||
|     "Show Tags": "Prikaži značke", | ||||
|     "Hide Tags": "Skrij značke", | ||||
|     Description: "Opis", | ||||
|     "No monitors available.": "Nobenega monitorja ni na voljo.", | ||||
|     "Add one": "Dodaj enega", | ||||
|     "No Monitors": "Ni monitorjev", | ||||
|     "Untitled Group": "Skupina brez imena", | ||||
|     Services: "Storitve", | ||||
|     Discard: "zavrzi", | ||||
|     Cancel: "Prekliči", | ||||
|     "Powered by": "Powered by", | ||||
|     shrinkDatabaseDescription: "Sprožitev podatkovne zbirke VACUUM za SQLite. Če je vaša zbirka podatkov ustvarjena po različici 1.10.0, je funkcija AUTO_VACUUM že omogočena in ta ukrep ni potreben.", | ||||
|     serwersms: "SerwerSMS.pl", | ||||
|     serwersmsAPIUser: "API uporabniško ime (vključno z webapi_ prefix)", | ||||
|     serwersmsAPIPassword: "API geslo", | ||||
|     serwersmsPhoneNumber: "Telefonska številka", | ||||
|     serwersmsSenderName: "Ime SMS pošiljatelja (registrirani prek portala za stranke)", | ||||
|     "stackfield": "Stackfield", | ||||
| }; | ||||
| @@ -12,7 +12,7 @@ export default { | ||||
|     pauseDashboardHome: "Pauziraj", | ||||
|     deleteMonitorMsg: "Da li ste sigurni da želite da obrišete ovog posmatrača?", | ||||
|     deleteNotificationMsg: "Da li ste sigurni d aželite da uklonite ovo obaveštenje za sve posmatrače?", | ||||
|     resoverserverDescription: "Cloudflare je podrazumevani server. Možete promeniti server za raszrešavanje u bilo kom trenutku.", | ||||
|     resolverserverDescription: "Cloudflare je podrazumevani server. Možete promeniti server za raszrešavanje u bilo kom trenutku.", | ||||
|     rrtypeDescription: "Odaberite RR-Type koji želite da posmatrate", | ||||
|     pauseMonitorMsg: "Da li ste sigurni da želite da pauzirate?", | ||||
|     Settings: "Podešavanja", | ||||
|   | ||||
| @@ -12,7 +12,7 @@ export default { | ||||
|     pauseDashboardHome: "Паузирај", | ||||
|     deleteMonitorMsg: "Да ли сте сигурни да желите да обришете овог посматрача?", | ||||
|     deleteNotificationMsg: "Да ли сте сигурни д ажелите да уклоните ово обавештење за све посматраче?", | ||||
|     resoverserverDescription: "Cloudflare је подразумевани сервер. Можете променити сервер за расзрешавање у било ком тренутку.", | ||||
|     resolverserverDescription: "Cloudflare је подразумевани сервер. Можете променити сервер за расзрешавање у било ком тренутку.", | ||||
|     rrtypeDescription: "Одаберите RR-Type који желите да посматрате", | ||||
|     pauseMonitorMsg: "Да ли сте сигурни да желите да паузирате?", | ||||
|     Settings: "Подешавања", | ||||
|   | ||||
| @@ -12,7 +12,7 @@ export default { | ||||
|     pauseDashboardHome: "Pausa", | ||||
|     deleteMonitorMsg: "Är du säker på att du vill ta bort den här övervakningen?", | ||||
|     deleteNotificationMsg: "Är du säker på att du vill ta bort den här notisen för alla övervakare?", | ||||
|     resoverserverDescription: "Cloudflare är den förvalda servern. Du kan byta resolver när som helst.", | ||||
|     resolverserverDescription: "Cloudflare är den förvalda servern. Du kan byta resolver när som helst.", | ||||
|     rrtypeDescription: "Välj den RR-typ du vill övervaka", | ||||
|     pauseMonitorMsg: "Är du säker på att du vill pausa?", | ||||
|     Settings: "Inställningar", | ||||
|   | ||||
| @@ -12,7 +12,7 @@ export default { | ||||
|     pauseDashboardHome: "Durdur", | ||||
|     deleteMonitorMsg: "Servisi silmek istediğinden emin misin?", | ||||
|     deleteNotificationMsg: "Bu bildirimi tüm servisler için silmek istediğinden emin misin?", | ||||
|     resoverserverDescription: "Cloudflare varsayılan sunucudur, çözümleyici sunucusunu istediğiniz zaman değiştirebilirsiniz.", | ||||
|     resolverserverDescription: "Cloudflare varsayılan sunucudur, çözümleyici sunucusunu istediğiniz zaman değiştirebilirsiniz.", | ||||
|     rrtypeDescription: "İzlemek istediğiniz servisin RR-Tipini seçin", | ||||
|     pauseMonitorMsg: "Durdurmak istediğinden emin misin?", | ||||
|     clearEventsMsg: "Bu servisin bütün kayıtlarını silmek istediğinden emin misin?", | ||||
|   | ||||
| @@ -1,31 +1,31 @@ | ||||
| export default { | ||||
|     languageName: "Vietnamese", | ||||
|     languageName: "Tiếng Việt", | ||||
|     checkEverySecond: "Kiểm tra mỗi {0} giây.", | ||||
|     retryCheckEverySecond: "Thử lại mỗi {0} giây.", | ||||
|     retriesDescription: "Số lần thử lại tối đa trước khi dịch vụ được đánh dấu là down và gửi thông báo.", | ||||
|     ignoreTLSError: "Bỏ qua lỗi TLS/SSL với các web HTTPS.", | ||||
|     upsideDownModeDescription: "Trạng thái đảo ngược, nếu dịch vụ có thể truy cập được nghĩa là DOWN.", | ||||
|     maxRedirectDescription: "Số lần chuyển hướng (redirect) tối đa. Đặt thành 0 để tắt chuyển hướng", | ||||
|     acceptedStatusCodesDescription: "Chọn mã code trạng thái được coi là phản hồi thành công.", | ||||
|     acceptedStatusCodesDescription: "Chọn mã trạng thái được coi là phản hồi thành công.", | ||||
|     passwordNotMatchMsg: "Mật khẩu nhập lại không khớp.", | ||||
|     notificationDescription: "Vui lòng chỉ định một kênh thông báo.", | ||||
|     keywordDescription: "Từ khoá tìm kiếm phản hồi ở dạng html hoặc JSON, có phân biệt chữ HOA - thường", | ||||
|     pauseDashboardHome: "Tạm dừng", | ||||
|     deleteMonitorMsg: "Bạn chắc chắn muốn xóa monitor này chứ?", | ||||
|     deleteNotificationMsg: "Bạn có chắc chắn muốn xóa kênh thông báo này cho tất cả monitor?", | ||||
|     resoverserverDescription: "Cloudflare là máy chủ mặc định, bạn có thể thay đổi bất cứ lúc nào.", | ||||
|     deleteMonitorMsg: "Bạn chắc chắn muốn xóa kênh theo dõi này chứ?", | ||||
|     deleteNotificationMsg: "Bạn có chắc chắn muốn xóa kênh thông báo này cho tất cả kênh theo dõi?", | ||||
|     resolverserverDescription: "Cloudflare là máy chủ mặc định, bạn có thể thay đổi bất cứ lúc nào.", | ||||
|     rrtypeDescription: "Hãy chọn RR-Type mà bạn muốn giám sát", | ||||
|     pauseMonitorMsg: "Bạn chắc chắn muốn tạm dừng chứ?", | ||||
|     enableDefaultNotificationDescription: "Bật làm mặc định cho mọi monitor mới về sau. Bạn vẫn có thể tắt thông báo riêng cho từng monitor.", | ||||
|     clearEventsMsg: "Bạn chắc chắn muốn xoá TẤT CẢ sự kiện cho monitor này chứ?", | ||||
|     clearHeartbeatsMsg: "Bạn chắc chắn muốn xoá TẤT CẢ heartbeats cho monitor này chứ?", | ||||
|     enableDefaultNotificationDescription: "Bật làm mặc định cho mọi kênh theo dõi mới về sau. Bạn vẫn có thể tắt thông báo riêng cho từng kênh theo dõi.", | ||||
|     clearEventsMsg: "Bạn chắc chắn muốn xoá TẤT CẢ sự kiện cho kênh theo dõi này chứ?", | ||||
|     clearHeartbeatsMsg: "Bạn chắc chắn muốn xoá TẤT CẢ heartbeats cho kênh theo dõi này chứ?", | ||||
|     confirmClearStatisticsMsg: "Bạn chắc chắn muốn xoá TẤT CẢ số liệu thống kê?", | ||||
|     importHandleDescription: "Chọn 'Skip existing' nếu bạn muốn bỏ qua mọi monitor và kênh thông báo trùng tên. 'Overwrite' sẽ ghi đè lên tất cả các monitor và kênh thông báo.", | ||||
|     importHandleDescription: "Chọn 'Giữ lại' nếu bạn muốn bỏ qua mọi kênh theo dõi và kênh thông báo trùng tên. 'Ghi đè' sẽ ghi đè lên tất cả các kênh theo dõi và kênh thông báo.", | ||||
|     confirmImportMsg: "Bạn có chắc chắn muốn khôi phục bản bản sao lưu này không?.", | ||||
|     twoFAVerifyLabel: "Vui lòng nhập mã token của bạn để xác minh rằng 2FA đang hoạt động", | ||||
|     tokenValidSettingsMsg: "Mã token hợp lệ! Bạn có thể lưu cài đặt 2FA bây giờ.", | ||||
|     confirmEnableTwoFAMsg: "Bạn chắc chắn muốn bật 2FA chứ?", | ||||
|     confirmDisableTwoFAMsg: "Bạn chắc chắn muốn tắt 2FA chứ?", | ||||
|     twoFAVerifyLabel: "Vui lòng nhập mã token của bạn để xác minh rằng xác thực 2 lớp (2FA) đang hoạt động", | ||||
|     tokenValidSettingsMsg: "Mã token hợp lệ! Bạn có thể lưu cài đặt xác thực 2 lớp (2FA) bây giờ.", | ||||
|     confirmEnableTwoFAMsg: "Bạn chắc chắn muốn bật xác thực 2 lớp (2FA) chứ?", | ||||
|     confirmDisableTwoFAMsg: "Bạn chắc chắn muốn tắt xác thực 2 lớp (2FA) chứ?", | ||||
|     Settings: "Cài đặt", | ||||
|     Dashboard: "Dashboard", | ||||
|     "New Update": "Bản cập nhật mới", | ||||
| @@ -38,7 +38,7 @@ export default { | ||||
|     "Check Update On GitHub": "Kiểm tra bản cập nhật mới trên GitHub", | ||||
|     List: "List", | ||||
|     Add: "Thêm", | ||||
|     "Add New Monitor": "Thêm mới Monitor", | ||||
|     "Add New Monitor": "Thêm mới kênh theo dõi", | ||||
|     "Quick Stats": "Thống kê nhanh", | ||||
|     Up: "Up", | ||||
|     Down: "Down", | ||||
| @@ -63,9 +63,9 @@ export default { | ||||
|     "-hour": "-giờ", | ||||
|     Response: "Phản hồi", | ||||
|     Ping: "Ping", | ||||
|     "Monitor Type": "Kiểu monitor", | ||||
|     "Monitor Type": "Kiểu kênh theo dõi", | ||||
|     Keyword: "Từ khoá", | ||||
|     "Friendly Name": "Tên monitor", | ||||
|     "Friendly Name": "Tên rút gọn", | ||||
|     URL: "URL", | ||||
|     Hostname: "Hostname", | ||||
|     Port: "Port", | ||||
| @@ -111,7 +111,7 @@ export default { | ||||
|     Password: "Mật khẩu", | ||||
|     "Remember me": "Lưu phiên đăng nhập", | ||||
|     Login: "Đăng nhập", | ||||
|     "No Monitors, please": "Không có monitor nào", | ||||
|     "No Monitors, please": "Không có kênh theo dõi nào", | ||||
|     "add one": "Thêm mới", | ||||
|     "Notification Type": "Kiểu thông báo", | ||||
|     Email: "Email", | ||||
| @@ -125,31 +125,31 @@ export default { | ||||
|     "Import Backup": "Khôi phục bản sao lưu", | ||||
|     "Export Backup": "Xuất bản sao lưu", | ||||
|     Export: "Xuất", | ||||
|     Import: "Khôi phục", | ||||
|     Import: "Nhập", | ||||
|     respTime: "Thời gian phản hồi (ms)", | ||||
|     notAvailableShort: "N/A", | ||||
|     "Default enabled": "Mặc định bật", | ||||
|     "Apply on all existing monitors": "Áp dụng cho tất cả monitor đang có", | ||||
|     "Apply on all existing monitors": "Áp dụng cho tất cả kênh theo dõi đang có", | ||||
|     Create: "Tạo", | ||||
|     "Clear Data": "Xoá dữ liệu", | ||||
|     Events: "Sự kiện", | ||||
|     Heartbeats: "Heartbeats", | ||||
|     "Auto Get": "Tự động lấy", | ||||
|     backupDescription: "Bạn có thể sao lưu tất cả các monitor và tất cả các thông báo vào một file JSON.", | ||||
|     backupDescription2: "PS: Không bao gồm dữ liệu lịch sử các sự kiện.", | ||||
|     backupDescription3: "Hãy lưu giữ file này cẩn thận vì trong file đó chứa cả các mã token thông báo.", | ||||
|     backupDescription: "Sao lưu tất cả các kênh theo dõi và tất cả các thông báo vào một file định dạng JSON.", | ||||
|     backupDescription2: "Lưu ý: Không bao gồm dữ liệu lịch sử các sự kiện.", | ||||
|     backupDescription3: "Hãy lưu giữ file này cẩn thận, trong file đó chứa cả các token thông báo.", | ||||
|     alertNoFile: "Hãy chọn file để khôi phục.", | ||||
|     alertWrongFileType: "Hãy chọn file JSON.", | ||||
|     alertWrongFileType: "Hãy chọn file định dạng JSON.", | ||||
|     "Clear all statistics": "Xoá tất cả thống kê", | ||||
|     "Skip existing": "Skip existing", | ||||
|     "Skip existing": "Giữ lại", | ||||
|     Overwrite: "Ghi đè", | ||||
|     Options: "Tuỳ chọn", | ||||
|     "Keep both": "Giữ lại cả hai", | ||||
|     "Verify Token": "Xác minh Token", | ||||
|     "Setup 2FA": "Cài đặt 2FA", | ||||
|     "Enable 2FA": "Bật 2FA", | ||||
|     "Disable 2FA": "Tắt 2FA", | ||||
|     "2FA Settings": "Cài đặt 2FA", | ||||
|     "Setup 2FA": "Cài đặt xác thực 2 lớp (2FA)", | ||||
|     "Enable 2FA": "Bật xác thực 2 lớp (2FA)", | ||||
|     "Disable 2FA": "Tắt xác thực 2 lớp (2FA)", | ||||
|     "2FA Settings": "Cài đặt xác thực 2 lớp (2FA)", | ||||
|     "Two Factor Authentication": "Xác thực hai yếu tố", | ||||
|     Active: "Hoạt động", | ||||
|     Inactive: "Ngừng hoạt động", | ||||
| @@ -170,16 +170,16 @@ export default { | ||||
|     Purple: "Tím", | ||||
|     Pink: "Hồng", | ||||
|     "Search...": "Tìm kiếm...", | ||||
|     "Avg. Ping": "Ping Trung bình", | ||||
|     "Avg. Ping": "Ping trung bình", | ||||
|     "Avg. Response": "Phản hồi trung bình", | ||||
|     "Entry Page": "Entry Page", | ||||
|     statusPageNothing: "Không có gì, hãy thêm nhóm monitor hoặc monitor.", | ||||
|     statusPageNothing: "Chưa có thông tin gì, hãy thêm nhóm kênh theo dõi hoặc kênh theo dõi.", | ||||
|     "No Services": "Không có dịch vụ", | ||||
|     "All Systems Operational": "Tất cả các hệ thống hoạt động bình thường", | ||||
|     "Partially Degraded Service": "Dịch vụ xuống cấp một phần", | ||||
|     "Degraded Service": "Degraded Service", | ||||
|     "Partially Degraded Service": "Có hệ thống bị ngưng", | ||||
|     "Degraded Service": "Toàn bộ hệ thống bị ngưng", | ||||
|     "Add Group": "Thêm nhóm", | ||||
|     "Add a monitor": "Thêm monitor", | ||||
|     "Add a monitor": "Thêm kênh theo dõi", | ||||
|     "Edit Status Page": "Sửa trang trạng thái", | ||||
|     "Go to Dashboard": "Đi tới Dashboard", | ||||
|     "Status Page": "Trang trạng thái", | ||||
| @@ -195,23 +195,23 @@ export default { | ||||
|     "YOUR BOT TOKEN HERE": "MÃ BOT TOKEN CỦA BẠN", | ||||
|     chatIDNotFound: "Không tìm thấy Chat ID, vui lòng gửi tin nhắn cho bot này trước", | ||||
|     webhook: "Webhook", | ||||
|     "Post URL": "URL đăng", | ||||
|     "Post URL": "URL webhook", | ||||
|     "Content Type": "Loại nội dung", | ||||
|     webhookJsonDesc: "{0} phù hợp với bất kỳ máy chủ http hiện đại nào như express.js", | ||||
|     webhookFormDataDesc: "{multipart} phù hợp với PHP, bạn chỉ cần phân tích cú pháp json bằng {decodeFunction}", | ||||
|     webhookJsonDesc: "{0} tương thích với máy chủ HTTP ví dụ như Express.js", | ||||
|     webhookFormDataDesc: "{multipart} tương thích với máy chủ PHP, bạn chỉ cần phân tích cú pháp json bằng {decodeFunction}", | ||||
|     smtp: "Email (SMTP)", | ||||
|     secureOptionNone: "None / STARTTLS (25, 587)", | ||||
|     secureOptionNone: "None/STARTTLS(25, 587)", | ||||
|     secureOptionTLS: "TLS (465)", | ||||
|     "Ignore TLS Error": "Bỏ qua lỗi TLS", | ||||
|     "From Email": "Từ Email", | ||||
|     "From Email": "Email gửi", | ||||
|     emailCustomSubject: "Tuỳ chỉnh tiêu đề", | ||||
|     "To Email": "Tới Email", | ||||
|     "To Email": "Email nhận", | ||||
|     smtpCC: "CC", | ||||
|     smtpBCC: "BCC", | ||||
|     discord: "Discord", | ||||
|     "Discord Webhook URL": "Discord Webhook URL", | ||||
|     wayToGetDiscordURL: "Để lấy Discord, hãy vào: Server Settings -> Integrations -> Create Webhook", | ||||
|     "Bot Display Name": "Tên hiển thị của Bot", | ||||
|     "Bot Display Name": "Tên hiển thị của BOT", | ||||
|     "Prefix Custom Message": "Tiền tố tin nhắn tuỳ chọn", | ||||
|     "Hello @everyone is...": "Xin chào {'@'} mọi người đang...", | ||||
|     teams: "Microsoft Teams", | ||||
| @@ -220,8 +220,8 @@ export default { | ||||
|     signal: "Tín hiệu", | ||||
|     Number: "Số", | ||||
|     Recipients: "Người nhận", | ||||
|     needSignalAPI: "Bạn cần một tín hiệu client với REST API.", | ||||
|     wayToCheckSignalURL: "Bạn có thể kiểm tra url này để xem cách thiết lập:", | ||||
|     needSignalAPI: "Bạn cần một tín hiệu kết nối với REST API.", | ||||
|     wayToCheckSignalURL: "Bạn có thể kiểm tra URL này để xem cách thiết lập:", | ||||
|     signalImportant: "QUAN TRỌNG: Bạn không thể kết hợp các nhóm và số trong người nhận!", | ||||
|     gotify: "Gotify", | ||||
|     "Application Token": "Mã Token ứng dụng", | ||||
| @@ -242,7 +242,8 @@ export default { | ||||
|     promosms: "PromoSMS", | ||||
|     clicksendsms: "ClickSend SMS", | ||||
|     lunasea: "LunaSea", | ||||
|     apprise: "Apprise (Hỗ trợ 50+ dịch vụ thông báo)", | ||||
|     apprise: "Apprise (Hỗ trợ trên 50 dịch vụ thông báo)", | ||||
|     GoogleChat: "Google Chat (Google Workspace only)", | ||||
|     pushbullet: "Pushbullet", | ||||
|     line: "Line Messenger", | ||||
|     mattermost: "Mattermost", | ||||
| @@ -260,7 +261,7 @@ export default { | ||||
|     apiCredentials: "API credentials", | ||||
|     octopushLegacyHint: "Bạn muốn sử dụng phiên bản cũ của Octopush (2011-2020) hay phiên bản mới?", | ||||
|     "Check octopush prices": "Kiểm tra giá octopush {0}.", | ||||
|     octopushPhoneNumber: "Số điện thoại (Định dạng intl, vd : +84123456789) ", | ||||
|     octopushPhoneNumber: "Số điện thoại (Định dạng intl, vd : +84692341165) ", | ||||
|     octopushSMSSender: "SMS người gửi : 3-11 ký tự chữ, số và dấu cách (a-zA-Z0-9)", | ||||
|     "LunaSea Device ID": "LunaSea ID thiết bị", | ||||
|     "Apprise URL": "Apprise URL", | ||||
| @@ -299,12 +300,65 @@ export default { | ||||
|     PushUrl: "Push URL", | ||||
|     HeadersInvalidFormat: "Header request không hợp lệ JSON: ", | ||||
|     BodyInvalidFormat: "Tequest body không hợp lệ JSON: ", | ||||
|     "Monitor History": "Lịch sử Monitor", | ||||
|     clearDataOlderThan: "Giữ dữ liệu lịch sử monitor {0} ngày.", | ||||
|     "Monitor History": "Lịch sử kênh theo dõi", | ||||
|     clearDataOlderThan: "Giữ dữ liệu lịch sử kênh theo dõi {0} ngày.", | ||||
|     PasswordsDoNotMatch: "Passwords không khớp.", | ||||
|     records: "records", | ||||
|     "One record": "One record", | ||||
|     steamApiKeyDescription: "Để monitor các Steam Game Server bạn cần một Steam Web-API key. Bạn có thể đăng ký API key tại đây: ", | ||||
|     steamApiKeyDescription: "Để theo dõi các Steam Game Server bạn cần một Steam Web-API key. Bạn có thể đăng ký API key tại đây: ", | ||||
|     "Current User": "User hiện tại", | ||||
|     recent: "Gần đây", | ||||
|     Done: "Hoàn thành", | ||||
|     Info: "Thông tin", | ||||
|     Security: "Bảo mật", | ||||
|     "Steam API Key": "Steam API Key", | ||||
|     "Shrink Database": "Shrink Database", | ||||
|     "Pick a RR-Type...": "Pick a RR-Type...", | ||||
|     "Pick Accepted Status Codes...": "Chọn các Codes trạng thái chấp nhận được...", | ||||
|     Default: "Mặc định", | ||||
|     "HTTP Options": "Tuỳ chọn HTTP", | ||||
|     "Create Incident": "Tạo Incident", | ||||
|     Title: "Tiêu đề", | ||||
|     Content: "Nội dung", | ||||
|     Style: "Style", | ||||
|     info: "thông tin", | ||||
|     warning: "cảnh báo", | ||||
|     danger: "nguy hiểm", | ||||
|     primary: "cơ sở", | ||||
|     light: "sáng", | ||||
|     dark: "tối", | ||||
|     Post: "Post", | ||||
|     "Please input title and content": "Hãy nhập tiêu đề và nội dung", | ||||
|     Created: "Đã tạo", | ||||
|     "Last Updated": "Cập nhật mới nhất", | ||||
|     Unpin: "Bỏ ghim", | ||||
|     "Switch to Light Theme": "Chuyển sang giao diện Sáng", | ||||
|     "Switch to Dark Theme": "Chuyển sang giao diện Tối", | ||||
|     "Show Tags": "Hiện Tags", | ||||
|     "Hide Tags": "Ẩn Tags", | ||||
|     Description: "Mô tả", | ||||
|     "No monitors available.": "Không có kênh theo dõi nào.", | ||||
|     "Add one": "Thêm mới", | ||||
|     "No Monitors": "Không có kênh theo dõi", | ||||
|     "Untitled Group": "Nhóm không có tiêu đề", | ||||
|     Services: "Dịch vụ", | ||||
|     Discard: "Bỏ", | ||||
|     Cancel: "Hủy", | ||||
|     "Powered by": "Được cung cấp bởi", | ||||
|     shrinkDatabaseDescription: "Khởi chạy database VACCUM cho SQLite. Nếu database được tạo sau version 1.10.0, AUTO_VACCUM đã được bật sẵn, hành động này không cần thiết.", | ||||
|     serwersms: "SerwerSMS.pl", | ||||
|     serwersmsAPIUser: "API Username (incl. webapi_ prefix)", | ||||
|     serwersmsAPIPassword: "API Password", | ||||
|     serwersmsPhoneNumber: "Số điện thoại", | ||||
|     serwersmsSenderName: "Tên người gửi SMS (Đã đăng ký qua portal)", | ||||
|     "stackfield": "Stackfield", | ||||
|     smtpDkimSettings: "Cài đặt xác thực Email(DKIM)", | ||||
|     smtpDkimDesc: "Xem hướng dẫn tại {0}.", | ||||
|     documentation: "Nodemailer DKIM", | ||||
|     smtpDkimDomain: "Mail domain", | ||||
|     smtpDkimKeySelector: "DKIM Key Selector", | ||||
|     smtpDkimPrivateKey: "Private Key", | ||||
|     smtpDkimHashAlgo: "Hash Algorithm (Tuỳ chọn)", | ||||
|     smtpDkimheaderFieldNames: "Header Keys to sign (Tuỳ chọn)", | ||||
|     smtpDkimskipFields: "Header Keys not to sign (Tuỳ chọn)", | ||||
| }; | ||||
| @@ -1,91 +1,104 @@ | ||||
| export default { | ||||
|     languageName: "简体中文", | ||||
|     checkEverySecond: "检测频率 {0} 秒", | ||||
|     retriesDescription: "最大重试失败次数", | ||||
|     ignoreTLSError: "忽略HTTPS站点的证书错误", | ||||
|     upsideDownModeDescription: "反向状态监控(状态码范围外为有效状态,反之为无效)", | ||||
|     maxRedirectDescription: "最大重定向次数,设置为 0 禁止重定向", | ||||
|     acceptedStatusCodesDescription: "选择被视为成功响应的状态码", | ||||
|     passwordNotMatchMsg: "两次密码输入不一致", | ||||
|     notificationDescription: "请为监控项配置消息通知", | ||||
|     keywordDescription: "检测响应内容中的关键字,区分大小写", | ||||
|     retryCheckEverySecond: "重试间隔 {0} 秒", | ||||
|     retriesDescription: "服务被标记为故障并发送通知之前得最大重试次数", | ||||
|     ignoreTLSError: "忽略 HTTPS 站点的 TLS/SSL 错误", | ||||
|     upsideDownModeDescription: "反转状态监控,如果服务可访问,则认为是故障。", | ||||
|     maxRedirectDescription: "允许的最大重定向次数。设置为 0 禁用重定向。", | ||||
|     acceptedStatusCodesDescription: "选择被视为成功响应的状态码。", | ||||
|     passwordNotMatchMsg: "两次输入的密码不一致。", | ||||
|     notificationDescription: "通知必须被分配给监控项才能正常工作。", | ||||
|     keywordDescription: "在纯 HTML 或 JSON 响应中搜索关键字,区分大小写。", | ||||
|     pauseDashboardHome: "暂停", | ||||
|     deleteMonitorMsg: "确定要删除此监控吗?", | ||||
|     deleteNotificationMsg: "确定要删除此消息通知吗?这将对所有监控生效。", | ||||
|     resoverserverDescription: "可自定义要使用的DNS服务器", | ||||
|     deleteMonitorMsg: "确定要删除此监控项吗?", | ||||
|     deleteNotificationMsg: "确定要为所有监控项删除此通知吗?", | ||||
|     resoverserverDescription: "默认服务器是 Cloudflare。您随时可以修改解析服务器。", | ||||
|     rrtypeDescription: "选择要监控的资源记录类型", | ||||
|     pauseMonitorMsg: "确定要暂停吗?", | ||||
|     enableDefaultNotificationDescription: "新的监控项将默认启用此通知,您仍然为每个监控项单独禁用。", | ||||
|     clearEventsMsg: "确定要删除此监控项的所有事件吗?", | ||||
|     clearHeartbeatsMsg: "确定要删除此监控项的所有心跳状态吗?", | ||||
|     confirmClearStatisticsMsg: "确定要删除所有统计信息吗?", | ||||
|     importHandleDescription: "如果想跳过同名的监控项或消息通知,请选择“跳过已存在”。“覆盖”将删除所有现有的监控项和通知。", | ||||
|     confirmImportMsg: "确定要导入备份吗?请确保已经选择了正确的导入选项。", | ||||
|     twoFAVerifyLabel: "请输入令牌码以确认二次验证:", | ||||
|     tokenValidSettingsMsg: "令牌码有效!您现在可以保存二次验证设置了。", | ||||
|     confirmEnableTwoFAMsg: "确定要启用二次验证吗?", | ||||
|     confirmDisableTwoFAMsg: "确定要禁用二次验证吗?", | ||||
|     Settings: "设置", | ||||
|     Dashboard: "仪表盘", | ||||
|     "New Update": "有新版本更新", | ||||
|     "New Update": "有新版本", | ||||
|     Language: "语言", | ||||
|     Appearance: "外观设置", | ||||
|     Appearance: "外观", | ||||
|     Theme: "主题", | ||||
|     General: "基本设置", | ||||
|     "Primary Base URL": "站点地址(URL)", | ||||
|     General: "常规", | ||||
|     "Primary Base URL": "站点主 URL", | ||||
|     About: "关于", | ||||
|     Version: "版本", | ||||
|     "Check Update On GitHub": "检查更新", | ||||
|     "Check Update On GitHub": "检查 GitHub 上的更新", | ||||
|     List: "列表", | ||||
|     Add: "添加", | ||||
|     "Add New Monitor": "创建监控项", | ||||
|     "Add New Monitor": "添加监控项", | ||||
|     "Quick Stats": "状态速览", | ||||
|     Up: "正常", | ||||
|     Down: "故障", | ||||
|     Pending: "检测失败", | ||||
|     Pending: "正在检测", | ||||
|     Unknown: "未知", | ||||
|     Pause: "暂停", | ||||
|     Name: "名称", | ||||
|     Status: "状态", | ||||
|     DateTime: "时间", | ||||
|     Message: "事件", | ||||
|     DateTime: "日期时间", | ||||
|     Message: "消息", | ||||
|     "No important events": "暂无重要事件", | ||||
|     Resume: "恢复", | ||||
|     Edit: "修改", | ||||
|     Edit: "编辑", | ||||
|     Delete: "删除", | ||||
|     Current: "当前", | ||||
|     Uptime: "可用率", | ||||
|     Uptime: "在线时间", | ||||
|     "Cert Exp.": "证书有效期", | ||||
|     days: "天", | ||||
|     day: "天", | ||||
|     "-day": " 天", | ||||
|     hour: "小时", | ||||
|     "-hour": " 小时", | ||||
|     Response: "响应时长", | ||||
|     Response: "响应", | ||||
|     Ping: "Ping", | ||||
|     "Monitor Type": "监控类型", | ||||
|     Keyword: "关键字", | ||||
|     "Friendly Name": "自定义名称", | ||||
|     URL: "网址URL", | ||||
|     "Friendly Name": "显示名称", | ||||
|     URL: "URL", | ||||
|     Hostname: "主机名", | ||||
|     Port: "端口号", | ||||
|     "Heartbeat Interval": "心跳间隔", | ||||
|     Retries: "重试次数", | ||||
|     Advanced: "高级选项", | ||||
|     "Upside Down Mode": "反向监控", | ||||
|     "Max. Redirects": "重定向次数", | ||||
|     "Heartbeat Retry Interval": "心跳重试间隔", | ||||
|     Advanced: "高级", | ||||
|     "Upside Down Mode": "反转监控", | ||||
|     "Max. Redirects": "最大重定向次数", | ||||
|     "Accepted Status Codes": "有效状态码", | ||||
|     "Push URL": "推送链接", | ||||
|     needPushEvery: "你需要每 {0} 秒调用一次", | ||||
|     "Push URL": "推送 URL", | ||||
|     needPushEvery: "您需要每 {0} 秒调用一次该 URL", | ||||
|     pushOptionalParams: "可选参数:{0}", | ||||
|     Save: "保存", | ||||
|     Notifications: "消息通知", | ||||
|     "Not available, please setup.": "无可用通道,请先设置", | ||||
|     Notifications: "通知", | ||||
|     "Not available, please setup.": "暂不可用,请先设置", | ||||
|     "Setup Notification": "设置通知", | ||||
|     Light: "明亮", | ||||
|     Dark: "黑暗", | ||||
|     Auto: "自动", | ||||
|     "Theme - Heartbeat Bar": "状态显示", | ||||
|     "Theme - Heartbeat Bar": "主题 - 心跳栏", | ||||
|     Normal: "正常显示", | ||||
|     Bottom: "靠下显示", | ||||
|     None: "不显示", | ||||
|     Timezone: "时区", | ||||
|     "Search Engine Visibility": "搜索引擎设置", | ||||
|     "Search Engine Visibility": "搜索引擎可见性", | ||||
|     "Allow indexing": "允许索引", | ||||
|     "Discourage search engines from indexing site": "阻止搜索引擎索引网站", | ||||
|     "Change Password": "修改密码", | ||||
|     "Current Password": "当前密码", | ||||
|     "New Password": "新的密码", | ||||
|     "Repeat New Password": "重复新的密码", | ||||
|     "New Password": "新密码", | ||||
|     "Repeat New Password": "重复新密码", | ||||
|     "Update Password": "更新密码", | ||||
|     "Disable Auth": "禁用身份验证", | ||||
|     "Enable Auth": "启用身份验证", | ||||
| @@ -93,73 +106,61 @@ export default { | ||||
|     Leave: "离开", | ||||
|     "I understand, please disable": "我已了解,继续禁用", | ||||
|     Confirm: "确认", | ||||
|     Yes: "确定", | ||||
|     No: "取消", | ||||
|     Yes: "是", | ||||
|     No: "否", | ||||
|     Username: "用户名", | ||||
|     Password: "密码", | ||||
|     "Remember me": "记住登录", | ||||
|     "Remember me": "记住我", | ||||
|     Login: "登录", | ||||
|     "No Monitors, please": "还没有监控项,", | ||||
|     "add one": "点击新增", | ||||
|     "Notification Type": "消息类型", | ||||
|     "add one": "点击添加", | ||||
|     "Notification Type": "通知类型", | ||||
|     Email: "邮件", | ||||
|     Test: "测试一下", | ||||
|     Test: "测试", | ||||
|     "Certificate Info": "证书信息", | ||||
|     "Resolver Server": "解析服务器", | ||||
|     "Resource Record Type": "资源记录类型", | ||||
|     "Last Result": "最后结果", | ||||
|     "Create your admin account": "创建管理员账号", | ||||
|     "Last Result": "上次结果", | ||||
|     "Create your admin account": "创建管理员账户", | ||||
|     "Repeat Password": "重复密码", | ||||
|     Backup: "备份", | ||||
|     "Import Backup": "导入备份", | ||||
|     "Export Backup": "导出备份", | ||||
|     Export: "导出", | ||||
|     Import: "导入", | ||||
|     respTime: "响应时间(毫秒)", | ||||
|     notAvailableShort: "N/A", | ||||
|     "Default enabled": "默认开启", | ||||
|     "Apply on all existing monitors": "应用到所有现有监控项", | ||||
|     Create: "创建", | ||||
|     clearEventsMsg: "确定要删除此监控项的所有事件吗?", | ||||
|     clearHeartbeatsMsg: "确定要删除此监控项的所有状态吗?", | ||||
|     confirmClearStatisticsMsg: "确定要删除所有统计信息吗?", | ||||
|     "Clear Data": "清除数据", | ||||
|     Events: "事件", | ||||
|     Heartbeats: "心跳", | ||||
|     "Auto Get": "自动获取", | ||||
|     enableDefaultNotificationDescription: "新的监控项将默认启用,你也可以在每个监控项中分别设置", | ||||
|     "Default enabled": "默认开启", | ||||
|     "Also apply to existing monitors": "应用到所有监控项", | ||||
|     Export: "导出", | ||||
|     Import: "导入", | ||||
|     backupDescription: "你可以将所有的监控项和消息通知备份到一个 JSON 文件中", | ||||
|     backupDescription2: "注意: 不包括历史状态和事件数据", | ||||
|     backupDescription3: "导出的文件中可能包含敏感信息,如消息通知的 Token 信息,请小心存放!", | ||||
|     alertNoFile: "请选择一个文件导入", | ||||
|     alertWrongFileType: "请选择一个 JSON 格式的文件", | ||||
|     twoFAVerifyLabel: "请输入Token以验证 2FA(二次验证)是否正常工作", | ||||
|     tokenValidSettingsMsg: "Token有效!您现在可以保存 2FA(二次验证)设置", | ||||
|     confirmEnableTwoFAMsg: "确定要启用 2FA(二次验证)吗?", | ||||
|     confirmDisableTwoFAMsg: "确定要禁用 2FA(二次验证)吗?", | ||||
|     "Apply on all existing monitors": "应用到所有监控项", | ||||
|     "Verify Token": "验证 Token", | ||||
|     "Setup 2FA": "设置 2FA", | ||||
|     "Enable 2FA": "启用 2FA", | ||||
|     "Disable 2FA": "禁用 2FA", | ||||
|     "2FA Settings": "2FA 设置", | ||||
|     "Two Factor Authentication": "双因素认证", | ||||
|     Active: "生效", | ||||
|     Inactive: "未生效", | ||||
|     Token: "Token", | ||||
|     "Show URI": "显示链接", | ||||
|     backupDescription: "您可以将所有监控项和通知备份到 JSON 文件。", | ||||
|     backupDescription2: "注意: 不包括历史状态和事件数据。", | ||||
|     backupDescription3: "导出的文件可能包含敏感信息,例如通知的令牌信息,请小心存放!", | ||||
|     alertNoFile: "请选择要导入的文件", | ||||
|     alertWrongFileType: "请选择一个 JSON 文件", | ||||
|     "Clear all statistics": "清除所有统计数据", | ||||
|     retryCheckEverySecond: "重试间隔 {0} 秒", | ||||
|     importHandleDescription: "如果想跳过同名的监控项或通知,请选择“跳过”;“覆盖”将删除所有现有的监控项和通知。", | ||||
|     confirmImportMsg: "确定要导入备份吗?请确保已经选择了正确的导入选项。", | ||||
|     "Heartbeat Retry Interval": "心跳重试间隔", | ||||
|     "Import Backup": "导入备份", | ||||
|     "Export Backup": "导出备份", | ||||
|     "Skip existing": "跳过", | ||||
|     "Skip existing": "跳过已存在", | ||||
|     Overwrite: "覆盖", | ||||
|     Options: "选项", | ||||
|     "Keep both": "全部保留", | ||||
|     "Verify Token": "验证令牌", | ||||
|     "Setup 2FA": "设置二次验证", | ||||
|     "Enable 2FA": "启用二次验证", | ||||
|     "Disable 2FA": "禁用二次验证", | ||||
|     "2FA Settings": "二次验证设置", | ||||
|     "Two Factor Authentication": "二次验证", | ||||
|     Active: "激活", | ||||
|     Inactive: "停用", | ||||
|     Token: "令牌", | ||||
|     "Show URI": "显示 URI", | ||||
|     Tags: "标签", | ||||
|     "Add New below or Select...": "在下面新增或选择...", | ||||
|     "Tag with this name already exist.": "相同名称的标签已存在", | ||||
|     "Tag with this value already exist.": "相同内容的标签已存在", | ||||
|     "Add New below or Select...": "在下面添加或选择...", | ||||
|     "Tag with this name already exist.": "相同名称的标签已存在。", | ||||
|     "Tag with this value already exist.": "相同内容的标签已存在。", | ||||
|     color: "颜色", | ||||
|     "value (optional)": "值(可选)", | ||||
|     Gray: "灰色", | ||||
| @@ -179,116 +180,196 @@ export default { | ||||
|     "All Systems Operational": "所有服务运行正常", | ||||
|     "Partially Degraded Service": "部分服务出现故障", | ||||
|     "Degraded Service": "全部服务出现故障", | ||||
|     "Add Group": "新建分组", | ||||
|     "Add Group": "添加分组", | ||||
|     "Add a monitor": "添加监控项", | ||||
|     "Edit Status Page": "编辑状态页", | ||||
|     "Edit Status Page": "编辑状态页面", | ||||
|     "Go to Dashboard": "前往仪表盘", | ||||
|     "Status Page": "状态页", | ||||
|     "Status Page": "状态页面", | ||||
|     defaultNotificationName: "{notification} 通知({number})", | ||||
|     here: "这里", | ||||
|     Required: "必填", | ||||
|     telegram: "Telegram", | ||||
|     "Bot Token": "Bot Token", | ||||
|     wayToGetTelegramToken: "您可以从 {0} 获取 Token。", | ||||
|     "Chat ID": "Chat ID", | ||||
|     supportTelegramChatID: "支持对话/群组/频道的 Chat ID", | ||||
|     wayToGetTelegramChatID: "您可以发送一条消息给您的机器人,然后访问此链接来查看 chat_id:", | ||||
|     "YOUR BOT TOKEN HERE": "这里替换成您的 BOT TOKEN", | ||||
|     chatIDNotFound: "未找到 Chat ID,请先给您的机器人发送一条消息。", | ||||
|     webhook: "Webhook", | ||||
|     "Post URL": "Post URL", | ||||
|     "Content Type": "Content Type", | ||||
|     webhookJsonDesc: "{0} 适合现代的 HTTP 服务器,例如 Express.js", | ||||
|     webhookFormDataDesc: "{multipart} 适合 PHP,其中 JSON 需要使用 {decodeFunction} 解码", | ||||
|     smtp: "电子邮件(SMTP)", | ||||
|     secureOptionNone: "无 / STARTTLS(常用端口 25、587)", | ||||
|     secureOptionTLS: "TLS(常用端口 465)", | ||||
|     "Ignore TLS Error": "忽略 TLS 错误", | ||||
|     "From Email": "发信人", | ||||
|     emailCustomSubject: "邮件主题", | ||||
|     "To Email": "收信人", | ||||
|     smtpCC: "抄送", | ||||
|     smtpBCC: "密送", | ||||
|     discord: "Discord", | ||||
|     "Discord Webhook URL": "Discord Webhook URL", | ||||
|     wayToGetDiscordURL: "要获取,可以前往服务器设置 -> 整合 -> 创建 Webhook", | ||||
|     "Bot Display Name": "机器人显示名称", | ||||
|     "Prefix Custom Message": "自定义消息前缀", | ||||
|     "Hello @everyone is...": "{'@'}everyone,……", | ||||
|     teams: "Microsoft Teams", | ||||
|     "Webhook URL": "Webhook URL", | ||||
|     wayToGetTeamsURL: "您可以在 {0} 了解如何获取 Webhook URL。", | ||||
|     signal: "Signal", | ||||
|     Number: "号码", | ||||
|     Recipients: "收件人", | ||||
|     needSignalAPI: "您需要有一个支持 REST API 的 Signal 客户端。", | ||||
|     wayToCheckSignalURL: "您可以通过下面的 URL 了解如何设置:", | ||||
|     signalImportant: "重要:您不能混合设定收件人的分组和号码!", | ||||
|     gotify: "Gotify", | ||||
|     "Application Token": "Application Token", | ||||
|     "Server URL": "服务器 URL", | ||||
|     Priority: "优先级", | ||||
|     slack: "Slack", | ||||
|     "rocket.chat": "Rocket.chat", | ||||
|     "Icon Emoji": "Emoji 图标", | ||||
|     "Channel Name": "频道名称", | ||||
|     "Uptime Kuma URL": "Uptime Kuma URL", | ||||
|     aboutWebhooks: "关于 Webhook 的更多信息:{0}", | ||||
|     aboutChannelName: "如果您想绕过 Webhook 频道,请在 {0} 字段输入所需的频道名称。例如:#other-channel", | ||||
|     aboutKumaURL: "如果保留 Uptime Kuma URL 为空,将会默认指向项目的 GitHub 页面。", | ||||
|     emojiCheatSheet: "Emoji 速查:{0}", | ||||
|     "rocket.chat": "Rocket.Chat", | ||||
|     pushover: "Pushover", | ||||
|     pushy: "Pushy", | ||||
|     octopush: "Octopush", | ||||
|     promosms: "PromoSMS", | ||||
|     clicksendsms: "ClickSend SMS", | ||||
|     lunasea: "LunaSea", | ||||
|     apprise: "Apprise (支持50+种通知服务)", | ||||
|     apprise: "Apprise (支持 50+ 种通知服务)", | ||||
|     GoogleChat: "Google Chat(仅 Google Workspace)", | ||||
|     pushbullet: "Pushbullet", | ||||
|     line: "Line Messenger", | ||||
|     mattermost: "Mattermost", | ||||
|     "Feishu WebHookUrl": "飞书 WebHook 地址", | ||||
|     defaultNotificationName: "{notification} 通知({number})", | ||||
|     here: "这里", | ||||
|     Required: "必填", | ||||
|     "Bot Token": "Bot Token", | ||||
|     wayToGetTelegramToken: "你可以从 {0} 获取 Token。", | ||||
|     "Chat ID": "Chat ID", | ||||
|     supportTelegramChatID: "支持对话/群组/频道的 ID", | ||||
|     wayToGetTelegramChatID: "你可以发送一条消息给你的机器人然后到下面的链接来查看你的 chat_id:", | ||||
|     "YOUR BOT TOKEN HERE": "这里替换成你的 BOT TOKEN", | ||||
|     chatIDNotFound: "没有找到 Chat ID,请先给你的机器人发送一条消息。", | ||||
|     "Post URL": "目标链接", | ||||
|     "Content Type": "Content Type", | ||||
|     webhookJsonDesc: "{0} 适合现代的服务,比如 express.js", | ||||
|     webhookFormDataDesc: "{multipart} 适合PHP,解码使用 {decodeFunction}", | ||||
|     secureOptionNone: "无 / STARTTLS(25,587)", | ||||
|     secureOptionTLS: "TLS(465)", | ||||
|     "Ignore TLS Error": "忽略 TLS 错误", | ||||
|     "From Email": "发信人", | ||||
|     "To Email": "收信人", | ||||
|     smtpCC: "抄送", | ||||
|     smtpBCC: "密送", | ||||
|     "Discord Webhook URL": "Discord Webhook 链接", | ||||
|     wayToGetDiscordURL: "获取方式:服务器设置 -> 整合 -> 创建 Webhook", | ||||
|     "Bot Display Name": "机器人显示名称", | ||||
|     "Prefix Custom Message": "自定义消息前缀", | ||||
|     "Hello @everyone is...": "{'@'}所有人,……", | ||||
|     "Webhook URL": "Webhook 链接", | ||||
|     wayToGetTeamsURL: "你可以在 {0} 获取 Webhook 链接。", | ||||
|     Number: "号码", | ||||
|     Recipients: "收件人", | ||||
|     needSignalAPI: "你需要有一个带 REST API 的 Signal 客户端。", | ||||
|     wayToCheckSignalURL: "你可以通过下面的链接来了解如何设置:", | ||||
|     signalImportant: "重要:你不能混合设定收件人的分组和号码!", | ||||
|     "Application Token": "Application Token", | ||||
|     "Server URL": "服务器链接", | ||||
|     Priority: "优先级", | ||||
|     "Icon Emoji": "Emoji 图标", | ||||
|     "Channel Name": "频道名称", | ||||
|     "Uptime Kuma URL": "Uptime Kuma 链接", | ||||
|     aboutWebhooks: "关于 Webhook 的更多信息:{0}", | ||||
|     aboutChannelName: "如果你想绕过 Webhook 设定的频道,请在设定 {0} 的频道名称字段为你想要的频道。例:#other-channel", | ||||
|     aboutKumaURL: "如果保留 Uptime Kuma 链接为空,将会默认指向项目的 Github 页面。", | ||||
|     emojiCheatSheet: "Emoji 参考表:{0}", | ||||
|     "User Key": "User Key", | ||||
|     Device: "设备", | ||||
|     "Message Title": "消息标题", | ||||
|     "Notification Sound": "通知铃声", | ||||
|     "More info on:": "更多信息:{0}", | ||||
|     pushoverDesc1: "紧急优先级(2)会在一小时内每30秒重试一次。", | ||||
|     pushoverDesc2: "如果你想发送通知给不同的设备,请填写“设备”字段。", | ||||
|     pushoverDesc1: "紧急优先级(2)会在一小时内每隔 30 秒重试一次。", | ||||
|     pushoverDesc2: "如果您想发送通知给不同的设备,请填写“设备”字段。", | ||||
|     "SMS Type": "短信类型", | ||||
|     octopushTypePremium: "Premium(快 - 推荐用于警报)", | ||||
|     octopushTypeLowCost: "Low Cost(慢 - 有时会被运营商屏蔽)", | ||||
|     checkPrice: "查看 {0} 的价格:", | ||||
|     apiCredentials: "API Credentials", | ||||
|     octopushLegacyHint: "您是否在使用旧版本的 Octopush(2011-2020)?", | ||||
|     "Check octopush prices": "查看 Octopush 的价格 {0}。", | ||||
|     octopushPhoneNumber: "电话号码(国际格式,例:+33612345678)", | ||||
|     octopushSMSSender: "短信发送名称:3-11位大小写字母、数字和空格(a-zA-Z0-9)", | ||||
|     octopushPhoneNumber: "电话号码(国际格式,例如:+33612345678)", | ||||
|     octopushSMSSender: "短信发送名称:3-11 位大小写字母、数字和空格(a-zA-Z0-9)", | ||||
|     "LunaSea Device ID": "LunaSea 设备 ID", | ||||
|     "Apprise URL": "Apprise 链接", | ||||
|     "Example:": "例:{0}", | ||||
|     "Apprise URL": "Apprise URL", | ||||
|     "Example:": "例如:{0}", | ||||
|     "Read more:": "了解更多:{0}", | ||||
|     "Status:": "状态:{0}", | ||||
|     "Read more": "了解更多", | ||||
|     appriseInstalled: "Apprise 已安装", | ||||
|     appriseNotInstalled: "Apprise 未安装。{0}", | ||||
|     "Access Token": "Access Token", | ||||
|     "Channel access token": "频道 access token", | ||||
|     "Line Developers Console": "Line Developers Console", | ||||
|     lineDevConsoleTo: "Line Developers Console - {0}", | ||||
|     "Basic Settings": "Basic Settings", | ||||
|     "User ID": "User ID", | ||||
|     "Channel access token": "频道 Access Token", | ||||
|     "Line Developers Console": "Line 开发者控制台", | ||||
|     lineDevConsoleTo: "Line 开发者控制台 - {0}", | ||||
|     "Basic Settings": "基本设置", | ||||
|     "User ID": "用户 ID", | ||||
|     "Messaging API": "Messaging API", | ||||
|     wayToGetLineChannelToken: "首先访问 {0},创建一个提供者和频道(Messaging API),然后你就可以从上面提到的地方获取频道的 access token 和用户 ID。", | ||||
|     "Icon URL": "图标链接", | ||||
|     aboutIconURL: "你可以在“Icon URL”中提供一个图片地址来覆盖默认的资料图片。如果设置了 Emoji 图标此字段会被忽略。", | ||||
|     aboutMattermostChannelName: "如果你想覆盖 Webhook 设定的频道,请在“频道名称”字段为你想要的频道。这需要在 Mattermost 的 Webhook 设定中启用。例:#other-channel", | ||||
|     wayToGetLineChannelToken: "首先访问 {0},创建一个提供者和频道(Messaging API),然后您就可以从上面提到的菜单获取频道的 Access Token 和用户 ID。", | ||||
|     "Icon URL": "图标 URL", | ||||
|     aboutIconURL: "您可以在“图标 URL”中提供一个图片链接来覆盖默认的资料图片。如果设置了 Emoji 图标则此字段会被忽略。", | ||||
|     aboutMattermostChannelName: "您可以覆盖 Webhook 发送消息的默认频道,只需在“频道名称”字段中输入您想要的频道名。这需要在 Mattermost 的 Webhook 设置中启用。例如:#other-channel", | ||||
|     matrix: "Matrix", | ||||
|     promosmsTypeEco: "SMS ECO - 便宜但是慢,并且容易超负荷。仅限波兰地区的收件人。", | ||||
|     promosmsTypeFlash: "SMS FLASH - 消息会自动显示在收件人设备上。仅限波兰地区的收件人。", | ||||
|     promosmsTypeFull: "SMS FULL - 高等级,你可以使用你自己的发件人名称(你需要先注册一个). 对于警报来说更可靠。", | ||||
|     promosmsTypeSpeed: "SMS SPEED - 最高优先级。非常快速可靠,但更贵(越两倍 SMS FULL 等级的价格)。", | ||||
|     promosmsPhoneNumber: "电话号码(波兰地区收件人可以不填区号)", | ||||
|     promosmsSMSSender: "短信发件人名称:已注册的名称或以下默认值之一:InfoSMS,SMS Info,MaxSMS,INFO,SMS", | ||||
|     checkPrice: "查看 {0} 的价格:", | ||||
|     octopushLegacyHint: "你是否在使用旧版本的 Octopush(2011-2020)?", | ||||
|     matrixHomeserverURL: "服务器链接(开头带 http(s):// 和可能的需要的端口号)", | ||||
|     "Internal Room Id": "Internal Room Id", | ||||
|     matrixDesc1: "你可以在 Matrix 客户端房间设置的高级选项找到 Internal Room Id。格式类似于 !QMdRCpUIfLwsfjxye6:home.server。", | ||||
|     matrixDesc2: "请不要使用你自己的 Access Token,这将开放你所有的账户权限和你加入的房间权限。你可以创建一个新的用户并邀请它至你允许的的房间中。你可以运行以下命令来获取 Access Token:{0}", | ||||
|     promosmsTypeEco: "SMS ECO - 便宜但是慢,并且容易超负荷。仅限波兰地区的收信人。", | ||||
|     promosmsTypeFlash: "SMS FLASH - 消息会自动显示在收信人设备上。仅限波兰地区的收信人。", | ||||
|     promosmsTypeFull: "SMS FULL - 高级短信,您可以使用您自己的发信人名称(需要先注册)。对于警报来说更可靠。", | ||||
|     promosmsTypeSpeed: "SMS SPEED - 最高优先级。非常快速可靠,但更贵(大约两倍 SMS FULL 的价格)。", | ||||
|     promosmsPhoneNumber: "电话号码(波兰地区收信人可以不填区号)", | ||||
|     promosmsSMSSender: "短信发信人名称:已注册的名称或以下默认值之一:InfoSMS、SMS Info、MaxSMS、INFO、SMS", | ||||
|     "Feishu WebHookUrl": "飞书 WebHook URL", | ||||
|     matrixHomeserverURL: "服务器 URL(包含 http(s):// 和可选的端口号)", | ||||
|     "Internal Room Id": "内部房间 ID", | ||||
|     matrixDesc1: "您可以在 Matrix 客户端房间设置的高级选项内找到内部房间 ID。格式类似于 !QMdRCpUIfLwsfjxye6:home.server。", | ||||
|     matrixDesc2: "请不要使用您自己的 Access Token,这将开放您所有的账户权限和您已加入房间的权限。我们强烈建议您创建一个新用户并邀请它至您接收通知的房间中。您可以运行以下命令来获取 Access Token:{0}", | ||||
|     Method: "方法", | ||||
|     Body: "请求体", | ||||
|     Headers: "请求头", | ||||
|     PushUrl: "推送 URL", | ||||
|     HeadersInvalidFormat: "请求头不是有效的 JSON: ", | ||||
|     BodyInvalidFormat: "请求体不是有效的 JSON: ", | ||||
|     "Monitor History": "监控历史", | ||||
|     clearDataOlderThan: "保留监控历史数据 {0} 天。", | ||||
|     PasswordsDoNotMatch: "密码不匹配", | ||||
|     records: "记录", | ||||
|     "One record": "一条记录", | ||||
|     steamApiKeyDescription: "要监控 Steam 游戏服务器,您需要 Steam Web-API 密钥。您可以在这里注册您的 API 密钥: ", | ||||
|     "Current User": "当前用户", | ||||
|     recent: "最近", | ||||
|     Done: "完成", | ||||
|     Info: "信息", | ||||
|     Security: "安全性", | ||||
|     "Steam API Key": "Steam API 密钥", | ||||
|     "Shrink Database": "压缩数据库", | ||||
|     "Pick a RR-Type...": "选择资源记录类型...", | ||||
|     "Pick Accepted Status Codes...": "选择有效的状态码...", | ||||
|     Default: "默认", | ||||
|     "HTTP Options": "HTTP 选项", | ||||
|     "Create Incident": "创建事件", | ||||
|     Title: "标题", | ||||
|     Content: "内容", | ||||
|     Style: "类型", | ||||
|     info: "信息", | ||||
|     warning: "警告", | ||||
|     danger: "危险", | ||||
|     primary: "主要", | ||||
|     light: "明亮", | ||||
|     dark: "黑暗", | ||||
|     Post: "发布", | ||||
|     "Please input title and content": "请输入标题和内容", | ||||
|     Created: "创建时间", | ||||
|     "Last Updated": "更新时间", | ||||
|     Unpin: "取消钉选", | ||||
|     "Switch to Light Theme": "切换到浅色主题", | ||||
|     "Switch to Dark Theme": "切换到深色主题", | ||||
|     "Show Tags": "显示标签", | ||||
|     "Hide Tags": "隐藏标签", | ||||
|     Description: "描述", | ||||
|     "No monitors available.": "没有可用的监控项。", | ||||
|     "Add one": "添加一个", | ||||
|     "No Monitors": "没有监控项", | ||||
|     "Untitled Group": "无标题分组", | ||||
|     Services: "服务", | ||||
|     Discard: "放弃", | ||||
|     Cancel: "取消", | ||||
|     "Powered by": "Powered by", | ||||
|     shrinkDatabaseDescription: "触发 SQLite 数据库的 VACUUM 命令,如果您的数据库是在 1.10.0 版本之后创建的,则已启用 AUTO_VACUUM,不再需要此操作。", | ||||
|     serwersms: "SerwerSMS.pl", | ||||
|     serwersmsAPIUser: "API 用户名(包括 webapi_ 前缀)", | ||||
|     serwersmsAPIPassword: "API 密码", | ||||
|     serwersmsPhoneNumber: "电话号码", | ||||
|     serwersmsSenderName: "SMS 发信人名称(需要在客户中心注册)", | ||||
|     stackfield: "Stackfield", | ||||
|     smtpDkimSettings: "DKIM 设置", | ||||
|     smtpDkimDesc: "请访问 Nodemailer DKIM {0} 了解配置方法。", | ||||
|     documentation: "文档", | ||||
|     smtpDkimDomain: "域名", | ||||
|     smtpDkimKeySelector: "前缀选择器", | ||||
|     smtpDkimPrivateKey: "密钥", | ||||
|     smtpDkimHashAlgo: "哈希算法(可选)", | ||||
|     smtpDkimheaderFieldNames: "包含在哈希计算对象内的 Header 列表(可选)", | ||||
|     smtpDkimskipFields: "不包含在哈希计算对象内的 Header 列表(可选)", | ||||
|     Feishu: "飞书", | ||||
|     AliyunSMS: "阿里云短信服务", | ||||
|     "Sms template must contain parameters: ": "短信模板必须包含以下变量:", | ||||
|     DingDing: "钉钉自定义机器人", | ||||
|     WebHookUrl: "钉钉自定义机器人 Webhook 地址", | ||||
|     SecretKey: "钉钉自定义机器人加签密钥", | ||||
|     "For safety, must use secret key": "出于安全考虑,必须使用加签密钥", | ||||
|     WeCom: "企业微信群机器人", | ||||
|     "WeCom Bot Key": "企业微信群机器人 Key", | ||||
| }; | ||||
|   | ||||
| @@ -100,7 +100,7 @@ export default { | ||||
|     deleteNotificationMsg: "是否確定刪除這個通知設定?如監測器啟用了這個通知,將會收不到通知。", | ||||
|     "Resolver Server": "DNS 伺服器", | ||||
|     "Resource Record Type": "DNS 記錄類型", | ||||
|     resoverserverDescription: "預設值為 Cloudflare DNS 伺服器,你可以轉用其他 DNS 伺服器。", | ||||
|     resolverserverDescription: "預設值為 Cloudflare DNS 伺服器,你可以轉用其他 DNS 伺服器。", | ||||
|     rrtypeDescription: "請選擇 DNS 記錄類型", | ||||
|     pauseMonitorMsg: "是否確定暫停?", | ||||
|     "Last Result": "最後結果", | ||||
|   | ||||
| @@ -13,8 +13,8 @@ export default { | ||||
|     pauseDashboardHome: "暫停", | ||||
|     deleteMonitorMsg: "您確定要刪除此監測器嗎?", | ||||
|     deleteNotificationMsg: "您確定要為所有監測器刪除此通知嗎?", | ||||
|     resoverserverDescription: "Cloudflare 為預設伺服器。您可以隨時更換解析伺服器。", | ||||
|     rrtypeDescription: "選擇您想要監測的資源記錄", | ||||
|     resolverserverDescription: "Cloudflare 為預設伺服器。您可以隨時更換解析伺服器。", | ||||
|     rrtypeDescription: "選擇您想要監測的資源記錄類型", | ||||
|     pauseMonitorMsg: "您確定要暫停嗎?", | ||||
|     enableDefaultNotificationDescription: "預設情況下,新監測器將啟用此通知。您仍可分別停用各監測器的通知。", | ||||
|     clearEventsMsg: "您確定要刪除此監測器的所有事件嗎?", | ||||
| @@ -307,4 +307,49 @@ export default { | ||||
|     "Showing {from} to {to} of {count} records": "正在顯示 {count} 項記錄中的 {from} 至 {to} 項", | ||||
|     steamApiKeyDescription: "若要監測 Steam 遊戲伺服器,您將需要 Steam Web-API 金鑰。您可以在此註冊您的 API 金鑰:", | ||||
|     "Current User": "目前使用者", | ||||
|     recent: "最近", | ||||
|     Done: "完成", | ||||
|     Info: "資訊", | ||||
|     Security: "安全性", | ||||
|     "Steam API Key": "Steam API 金鑰", | ||||
|     "Shrink Database": "壓縮資料庫", | ||||
|     "Pick a RR-Type...": "選擇資源記錄類型...", | ||||
|     "Pick Accepted Status Codes...": "選擇可接受的狀態碼...", | ||||
|     Default: "預設", | ||||
|     "HTTP Options": "HTTP 選項", | ||||
|     "Create Incident": "建立事件", | ||||
|     Title: "標題", | ||||
|     Content: "內容", | ||||
|     Style: "樣式", | ||||
|     info: "資訊", | ||||
|     warning: "警告", | ||||
|     danger: "危險", | ||||
|     primary: "主要", | ||||
|     light: "淺色", | ||||
|     dark: "暗色", | ||||
|     Post: "發佈", | ||||
|     "Please input title and content": "請輸入標題及內容", | ||||
|     Created: "建立", | ||||
|     "Last Updated": "最後更新", | ||||
|     Unpin: "取消釘選", | ||||
|     "Switch to Light Theme": "切換至淺色佈景主題", | ||||
|     "Switch to Dark Theme": "切換至深色佈景主題", | ||||
|     "Show Tags": "顯示標籤", | ||||
|     "Hide Tags": "隱藏標籤", | ||||
|     Description: "說明", | ||||
|     "No monitors available.": "沒有可用的監測器。", | ||||
|     "Add one": "新增一個", | ||||
|     "No Monitors": "無監測器", | ||||
|     "Untitled Group": "未命名群組", | ||||
|     Services: "服務", | ||||
|     Discard: "捨棄", | ||||
|     Cancel: "取消", | ||||
|     "Powered by": "技術支援", | ||||
|     shrinkDatabaseDescription: "觸發 SQLite 的資料庫清理 (VACUUM)。如果您的資料庫是在 1.10.0 版本後建立,AUTO_VACUUM 已自動啟用,則無需此操作。", | ||||
|     serwersms: "SerwerSMS.pl", | ||||
|     serwersmsAPIUser: "API 使用者名稱 (包括 webapi_ 前綴)", | ||||
|     serwersmsAPIPassword: "API 密碼", | ||||
|     serwersmsPhoneNumber: "電話號碼", | ||||
|     serwersmsSenderName: "SMS 寄件人名稱 (由客戶入口網站註冊)", | ||||
|     "stackfield": "Stackfield", | ||||
| }; | ||||
|   | ||||
| @@ -87,7 +87,7 @@ | ||||
|                                     <label for="dns_resolve_server" class="form-label">{{ $t("Resolver Server") }}</label> | ||||
|                                     <input id="dns_resolve_server" v-model="monitor.dns_resolve_server" type="text" class="form-control" :pattern="ipRegex" required> | ||||
|                                     <div class="form-text"> | ||||
|                                         {{ $t("resoverserverDescription") }} | ||||
|                                         {{ $t("resolverserverDescription") }} | ||||
|                                     </div> | ||||
|                                 </div> | ||||
|  | ||||
| @@ -276,7 +276,7 @@ | ||||
|  | ||||
|                                 <div class="my-3"> | ||||
|                                     <label for="basicauth" class="form-label">{{ $t("Password") }}</label> | ||||
|                                     <input id="basicauth-pass" v-model="monitor.basic_auth_pass" type="password" class="form-control" :placeholder="$t('Password')"> | ||||
|                                     <input id="basicauth-pass" v-model="monitor.basic_auth_pass" type="password" autocomplete="new-password" class="form-control" :placeholder="$t('Password')"> | ||||
|                                 </div> | ||||
|                             </template> | ||||
|                         </div> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user