diff --git a/package.json b/package.json index 0f6172344..dc3dedca0 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "uptime-kuma", - "version": "1.11.3", + "version": "1.11.4", "license": "MIT", "repository": { "type": "git", @@ -30,13 +30,13 @@ "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.3-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.3 -t louislam/uptime-kuma:debian -t louislam/uptime-kuma:1-debian -t louislam/uptime-kuma:1.11.3-debian --target release . --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.4-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.4 -t louislam/uptime-kuma:debian -t louislam/uptime-kuma:1-debian -t louislam/uptime-kuma:1.11.4-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.3 && npm ci --production && npm run download-dist", + "setup": "git checkout 1.11.4 && 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", diff --git a/server/notification-providers/mattermost.js b/server/notification-providers/mattermost.js index d776284be..c2ffc23b8 100644 --- a/server/notification-providers/mattermost.js +++ b/server/notification-providers/mattermost.js @@ -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; diff --git a/src/components/settings/Security.vue b/src/components/settings/Security.vue index 94c6b5a67..ede0d90c2 100644 --- a/src/components/settings/Security.vue +++ b/src/components/settings/Security.vue @@ -215,12 +215,24 @@
Dette er for de som har tredjepartsautorisering foran Uptime Kuma, for eksempel Cloudflare Access.
Vennligst vær forsiktig.
+ + +Opravdu chcete deaktivovat autentifikaci?
+Tato možnost je určena pro případy, kdy máte autentifikaci zajištěnou třetí stranou ještě před přístupem do Uptime Kuma, například prostřednictvím Cloudflare Access.
+Používejte ji prosím s rozmyslem.
+ + + +Bạn có muốn TẮT XÁC THỰC không?
+Điều này rất nguy hiểmBẤT KỲ AI cũng có thể truy cập và cướp quyền điều khiển.
+Vui lòng cẩn thận.
+ -Are you sure want to disable auth?
-It is for someone who have 3rd-party auth in front of Uptime Kuma such as Cloudflare Access.
-Please use it carefully.
+Are you sure want to disable authentication?
+It is designed for scenarios where you intend to implement third-party authentication in front of Uptime Kuma such as Cloudflare Access, Authelia or other authentication mechanisms.
+Please use this option carefully!
diff --git a/src/i18n.js b/src/i18n.js index cdb93e955..8d9b2fafa 100644 --- a/src/i18n.js +++ b/src/i18n.js @@ -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)", @@ -27,7 +28,7 @@ const languageList = { "zh-CN": "简体中文", "pl": "Polski", "et-EE": "eesti", - "vi": "Vietnamese", + "vi-VN": "Tiếng Việt", "zh-TW": "繁體中文 (台灣)" }; diff --git a/src/languages/cs-CZ.js b/src/languages/cs-CZ.js new file mode 100644 index 000000000..8e74b9b78 --- /dev/null +++ b/src/languages/cs-CZ.js @@ -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?", + resoverserverDescription: "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é)", +}; diff --git a/src/languages/vi.js b/src/languages/vi-VN.js similarity index 79% rename from src/languages/vi.js rename to src/languages/vi-VN.js index 22538f917..ec9e9efc6 100644 --- a/src/languages/vi.js +++ b/src/languages/vi-VN.js @@ -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?", + 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?", resoverserverDescription: "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": "Có hệ thống down", - "Degraded Service": "Toàn bộ hệ thống down", + "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,7 @@ 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", @@ -261,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", @@ -300,50 +300,50 @@ 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: "Done", - Info: "Info", - Security: "Security", + 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": "Create Incident", + "Create Incident": "Tạo Incident", Title: "Tiêu đề", Content: "Nội dung", Style: "Style", - info: "info", + info: "thông tin", warning: "cảnh báo", danger: "nguy hiểm", - primary: "primary", + 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: "Created", + Created: "Đã tạo", "Last Updated": "Cập nhật mới nhất", Unpin: "Bỏ ghim", - "Switch to Light Theme": "Chuyển sang Theme Sáng", - "Switch to Dark Theme": "Chuyển sang Theme Tối", + "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ó monitor nào.", + "No monitors available.": "Không có kênh theo dõi nào.", "Add one": "Thêm mới", - "No Monitors": "No Monitors", + "No Monitors": "Không có kênh theo dõi", "Untitled Group": "Nhóm không có tiêu đề", - Services: "Services", - Discard: "Discard", - Cancel: "Cancel", + 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", @@ -352,11 +352,11 @@ export default { serwersmsPhoneNumber: "Số điện thoại", serwersmsSenderName: "Tên người gửi SMS (Đã đăng ký qua portal)", "stackfield": "Stackfield", - smtpDkimSettings: "DKIM Settings", - smtpDkimDesc: "Please refer to the Nodemailer DKIM {0} for usage.", - documentation: "documentation", - smtpDkimDomain: "Domain Name", - smtpDkimKeySelector: "Key Selector", + 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)", diff --git a/src/languages/zh-CN.js b/src/languages/zh-CN.js index ecf91979c..aeb6c29ab 100644 --- a/src/languages/zh-CN.js +++ b/src/languages/zh-CN.js @@ -23,6 +23,7 @@ export default { Theme: "主题", General: "基本设置", "Primary Base URL": "站点地址(URL)", + About: "关于", Version: "版本", "Check Update On GitHub": "检查更新", List: "列表", @@ -150,6 +151,7 @@ export default { importHandleDescription: "如果想跳过同名的监控项或通知,请选择“跳过”;“覆盖”将删除所有现有的监控项和通知。", confirmImportMsg: "确定要导入备份吗?请确保已经选择了正确的导入选项。", "Heartbeat Retry Interval": "心跳重试间隔", + "Backup": "备份", "Import Backup": "导入备份", "Export Backup": "导出备份", "Skip existing": "跳过",