feat: Add server installation dialog and commands

This commit is contained in:
web 2025-10-28 02:10:12 -07:00
parent ad60ea9b18
commit 4429c9ddc9
26 changed files with 246 additions and 8 deletions

View File

@ -1,23 +1,22 @@
<a name="readme-top"></a>
# Changelog
## [1.5.4](https://github.com/perfect-panel/ppanel-web/compare/v1.5.3...v1.5.4) (2025-10-26)
### 🐛 Bug Fixes
* Update generateRealityKeyPair to use async key generation ([e60e369](https://github.com/perfect-panel/ppanel-web/commit/e60e369))
* Update the wallet localization file and add new fields such as automatic reset and recharge ([88aa965](https://github.com/perfect-panel/ppanel-web/commit/88aa965))
- Update generateRealityKeyPair to use async key generation ([e60e369](https://github.com/perfect-panel/ppanel-web/commit/e60e369))
- Update the wallet localization file and add new fields such as automatic reset and recharge ([88aa965](https://github.com/perfect-panel/ppanel-web/commit/88aa965))
## [1.5.3](https://github.com/perfect-panel/ppanel-web/compare/v1.5.2...v1.5.3) (2025-10-21)
### 🐛 Bug Fixes
* Fix bugs ([a46657d](https://github.com/perfect-panel/ppanel-web/commit/a46657d))
* Fix dependencies ([8bd25d6](https://github.com/perfect-panel/ppanel-web/commit/8bd25d6))
* Remove unnecessary migration function code and add device configuration options ([521a7a9](https://github.com/perfect-panel/ppanel-web/commit/521a7a9))
* Update bun.lockb to reflect dependency changes ([ca892dd](https://github.com/perfect-panel/ppanel-web/commit/ca892dd))
- Fix bugs ([a46657d](https://github.com/perfect-panel/ppanel-web/commit/a46657d))
- Fix dependencies ([8bd25d6](https://github.com/perfect-panel/ppanel-web/commit/8bd25d6))
- Remove unnecessary migration function code and add device configuration options ([521a7a9](https://github.com/perfect-panel/ppanel-web/commit/521a7a9))
- Update bun.lockb to reflect dependency changes ([ca892dd](https://github.com/perfect-panel/ppanel-web/commit/ca892dd))
<a name="readme-top"></a>

View File

@ -21,6 +21,7 @@ import DynamicMultiplier from './dynamic-multiplier';
import OnlineUsersCell from './online-users-cell';
import ServerConfig from './server-config';
import ServerForm from './server-form';
import ServerInstall from './server-install';
function PctBar({ value }: { value: number }) {
const v = value.toFixed(2);
@ -224,6 +225,7 @@ export default function ServersPage() {
}
}}
/>,
<ServerInstall key='install' server={row} />,
<ConfirmButton
key='delete'
trigger={

View File

@ -0,0 +1,119 @@
'use client';
import { getNodeConfig } from '@/services/admin/system';
import { useQuery } from '@tanstack/react-query';
import { Button } from '@workspace/ui/components/button';
import {
Dialog,
DialogContent,
DialogFooter,
DialogHeader,
DialogTitle,
DialogTrigger,
} from '@workspace/ui/components/dialog';
import { Input } from '@workspace/ui/components/input';
import { Label } from '@workspace/ui/components/label';
import { useTranslations } from 'next-intl';
import React, { useCallback, useEffect, useMemo, useState } from 'react';
import { toast } from 'sonner';
type Props = {
server: API.Server;
};
export default function ServerInstall({ server }: Props) {
const t = useTranslations('servers');
const [open, setOpen] = useState(false);
const [domain, setDomain] = useState('');
const { data: cfgResp } = useQuery({
queryKey: ['getNodeConfig'],
queryFn: async () => {
const { data } = await getNodeConfig();
return data.data as API.NodeConfig | undefined;
},
enabled: open,
});
useEffect(() => {
if (open) {
const host = localStorage.getItem('API_HOST') ?? window.location.origin;
setDomain(host);
}
}, [open]);
const installCommand = useMemo(() => {
const secret = cfgResp?.node_secret ?? '';
return `wget -N https://raw.githubusercontent.com/perfect-panel/ppanel-node/master/scripts/install.sh && bash install.sh --api-host ${domain} --server-id ${server.id} --secret-key ${secret}`;
}, [domain, server.id, cfgResp?.node_secret]);
async function handleCopy() {
try {
if (navigator?.clipboard?.writeText) {
await navigator.clipboard.writeText(installCommand);
} else {
// fallback for environments without clipboard API
const el = document.createElement('textarea');
el.value = installCommand;
document.body.appendChild(el);
el.select();
document.execCommand('copy');
document.body.removeChild(el);
}
toast.success(t('copied'));
setOpen(false);
} catch (error) {
toast.error(t('copyFailed'));
}
}
const onDomainChange = useCallback((e: React.ChangeEvent<HTMLInputElement>) => {
setDomain(e.target.value);
localStorage.setItem('API_HOST', e.target.value);
}, []);
return (
<Dialog open={open} onOpenChange={setOpen}>
<DialogTrigger asChild>
<Button variant='secondary'>{t('connect')}</Button>
</DialogTrigger>
<DialogContent className='w-[720px] max-w-full md:max-w-screen-md'>
<DialogHeader>
<DialogTitle>{t('oneClickInstall')}</DialogTitle>
</DialogHeader>
<div className='space-y-4'>
<div>
<Label>{t('apiHost')}</Label>
<div className='flex items-center gap-2'>
<Input
value={domain}
placeholder={t('apiHostPlaceholder')}
onChange={onDomainChange}
/>
</div>
</div>
<div>
<Label>{t('installCommand')}</Label>
<div className='flex flex-col gap-2'>
<textarea
readOnly
aria-label={t('installCommand')}
value={installCommand}
className='min-h-[88px] w-full rounded border p-2 font-mono text-sm'
/>
</div>
</div>
</div>
<DialogFooter className='flex-row justify-end gap-2 pt-3'>
<Button variant='outline' onClick={() => setOpen(false)}>
{t('close')}
</Button>
<Button onClick={handleCopy}>{t('copyAndClose')}</Button>
</DialogFooter>
</DialogContent>
</Dialog>
);
}

View File

@ -5,6 +5,8 @@
},
"address": "Adresa",
"address_placeholder": "Adresa serveru",
"apiHost": "API hostitel",
"apiHostPlaceholder": "http(s)://example.com",
"bandwidth_placeholder": "Zadejte šířku pásma, nechte prázdné pro BBR",
"basic": "Základní konfigurace",
"cancel": "Zrušit",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "Tuto akci nelze vrátit zpět.",
"confirmDeleteTitle": "Smazat tento server?",
"congestion_controller": "Ovladač přetížení",
"connect": "Připojit",
"copied": "Zkopírováno",
"copy": "Kopírovat",
"country": "Země",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "např. 1-65535",
"host": "Hostitel",
"id": "ID",
"installCommand": "Instalační příkaz",
"ipAddresses": "IP adresy",
"memory": "Paměť",
"migrate": "Migrace dat",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Zadejte heslo pro obfuskaci",
"obfs_path": "Obfs cesta",
"offline": "Offline",
"oneClickInstall": "Instalace jedním kliknutím",
"online": "Online",
"onlineUsers": "Online uživatelé",
"padding_scheme": "Schéma vycpání",

View File

@ -5,6 +5,8 @@
},
"address": "Adresse",
"address_placeholder": "Serveradresse",
"apiHost": "API-Host",
"apiHostPlaceholder": "http(s)://beispiel.de",
"bandwidth_placeholder": "Geben Sie die Bandbreite ein, lassen Sie das Feld leer für BBR",
"basic": "Grundkonfiguration",
"cancel": "Abbrechen",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "Diese Aktion kann nicht rückgängig gemacht werden.",
"confirmDeleteTitle": "Diesen Server löschen?",
"congestion_controller": "Staukontroller",
"connect": "Verbinden",
"copied": "Kopiert",
"copy": "Kopieren",
"country": "Land",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "z.B. 1-65535",
"host": "Host",
"id": "ID",
"installCommand": "Installationsbefehl",
"ipAddresses": "IP-Adressen",
"memory": "Speicher",
"migrate": "Daten migrieren",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Obfuskationspasswort eingeben",
"obfs_path": "Obfs-Pfad",
"offline": "Offline",
"oneClickInstall": "Ein-Klick-Installation",
"online": "Online",
"onlineUsers": "Online-Benutzer",
"padding_scheme": "Polsterungsschema",

View File

@ -5,6 +5,8 @@
},
"address": "Address",
"address_placeholder": "Server address",
"apiHost": "API Host",
"apiHostPlaceholder": "http(s)://example.com",
"bandwidth_placeholder": "Enter bandwidth, leave empty for BBR",
"basic": "Basic Configuration",
"cancel": "Cancel",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "This action cannot be undone.",
"confirmDeleteTitle": "Delete this server?",
"congestion_controller": "Congestion controller",
"connect": "Connect",
"copied": "Copied",
"copy": "Copy",
"country": "Country",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "e.g. 1-65535",
"host": "Host",
"id": "ID",
"installCommand": "Install command",
"ipAddresses": "IP addresses",
"memory": "Memory",
"migrate": "Migrate Data",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Enter obfuscation password",
"obfs_path": "Obfs Path",
"offline": "Offline",
"oneClickInstall": "One-click Install",
"online": "Online",
"onlineUsers": "Online users",
"padding_scheme": "Padding Scheme",

View File

@ -5,6 +5,8 @@
},
"address": "Dirección",
"address_placeholder": "Dirección del servidor",
"apiHost": "Host de API",
"apiHostPlaceholder": "http(s)://ejemplo.com",
"bandwidth_placeholder": "Introduce el ancho de banda, deja vacío para BBR",
"basic": "Configuración Básica",
"cancel": "Cancelar",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "Esta acción no se puede deshacer.",
"confirmDeleteTitle": "¿Eliminar este servidor?",
"congestion_controller": "Controlador de congestión",
"connect": "Conectar",
"copied": "Copiado",
"copy": "Copiar",
"country": "País",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "p. ej. 1-65535",
"host": "Host",
"id": "ID",
"installCommand": "Comando de instalación",
"ipAddresses": "Direcciones IP",
"memory": "Memoria",
"migrate": "Migrar datos",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Ingrese la contraseña de ofuscación",
"obfs_path": "Ruta de Ofuscación",
"offline": "Desconectado",
"oneClickInstall": "Instalación con un clic",
"online": "Conectado",
"onlineUsers": "Usuarios en línea",
"padding_scheme": "Esquema de Relleno",

View File

@ -5,6 +5,8 @@
},
"address": "Dirección",
"address_placeholder": "Dirección del servidor",
"apiHost": "Host de API",
"apiHostPlaceholder": "http(s)://ejemplo.com",
"bandwidth_placeholder": "Ingresa el ancho de banda, deja vacío para BBR",
"basic": "Configuración Básica",
"cancel": "Cancelar",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "Esta acción no se puede deshacer.",
"confirmDeleteTitle": "¿Eliminar este servidor?",
"congestion_controller": "Controlador de congestión",
"connect": "Conectar",
"copied": "Copiado",
"copy": "Copiar",
"country": "País",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "p. ej. 1-65535",
"host": "Host",
"id": "ID",
"installCommand": "Comando de instalación",
"ipAddresses": "Direcciones IP",
"memory": "Memoria",
"migrate": "Migrar datos",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Ingresa la contraseña de ofuscación",
"obfs_path": "Ruta de Ofuscación",
"offline": "Desconectado",
"oneClickInstall": "Instalación con un clic",
"online": "Conectado",
"onlineUsers": "Usuarios en línea",
"padding_scheme": "Esquema de Relleno",

View File

@ -5,6 +5,8 @@
},
"address": "آدرس",
"address_placeholder": "آدرس سرور",
"apiHost": "میزبان API",
"apiHostPlaceholder": "http(s)://example.com",
"bandwidth_placeholder": "عرض پهنای باند، برای BBR خالی بگذارید",
"basic": "پیکربندی پایه",
"cancel": "لغو",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "این عمل قابل بازگشت نیست.",
"confirmDeleteTitle": "آیا این سرور را حذف کنید؟",
"congestion_controller": "کنترل‌کننده ترافیک",
"connect": "اتصال",
"copied": "کپی شد",
"copy": "کپی",
"country": "کشور",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "مثلاً 1-65535",
"host": "میزبان",
"id": "شناسه",
"installCommand": "دستور نصب",
"ipAddresses": "آدرس‌های IP",
"memory": "حافظه",
"migrate": "انتقال داده",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "رمز عبور اختفا را وارد کنید",
"obfs_path": "مسیر پنهان‌سازی",
"offline": "آفلاین",
"oneClickInstall": "نصب با یک کلیک",
"online": "آنلاین",
"onlineUsers": "کاربران آنلاین",
"padding_scheme": "طرح پدینگ",

View File

@ -5,6 +5,8 @@
},
"address": "Osoite",
"address_placeholder": "Palvelimen osoite",
"apiHost": "API-isäntä",
"apiHostPlaceholder": "http(s)://esimerkki.com",
"bandwidth_placeholder": "Syötä kaistanleveys, jätä tyhjäksi BBR:lle",
"basic": "Perusasetukset",
"cancel": "Peruuta",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "Tätä toimintoa ei voi peruuttaa.",
"confirmDeleteTitle": "Poista tämä palvelin?",
"congestion_controller": "Ruuhkansäätö",
"connect": "Yhdistä",
"copied": "Kopioitu",
"copy": "Kopioi",
"country": "Maa",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "esim. 1-65535",
"host": "Isäntä",
"id": "ID",
"installCommand": "Asennuskomento",
"ipAddresses": "IP-osoitteet",
"memory": "Muisti",
"migrate": "Siirrä tiedot",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Syötä häilytyssalasana",
"obfs_path": "Häilytys polku",
"offline": "Offline",
"oneClickInstall": "Yhden napsautuksen asennus",
"online": "Online",
"onlineUsers": "Verkossa olevat käyttäjät",
"padding_scheme": "Täyttökaavio",

View File

@ -5,6 +5,8 @@
},
"address": "Adresse",
"address_placeholder": "Adresse du serveur",
"apiHost": "Hôte API",
"apiHostPlaceholder": "http(s)://exemple.com",
"bandwidth_placeholder": "Entrez la bande passante, laissez vide pour BBR",
"basic": "Configuration de base",
"cancel": "Annuler",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "Cette action ne peut pas être annulée.",
"confirmDeleteTitle": "Supprimer ce serveur ?",
"congestion_controller": "Contrôleur de congestion",
"connect": "Se connecter",
"copied": "Copié",
"copy": "Copier",
"country": "Pays",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "ex. 1-65535",
"host": "Hôte",
"id": "ID",
"installCommand": "Commande d'installation",
"ipAddresses": "Adresses IP",
"memory": "Mémoire",
"migrate": "Migrer les données",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Entrez le mot de passe d'obfuscation",
"obfs_path": "Chemin Obfs",
"offline": "Hors ligne",
"oneClickInstall": "Installation en un clic",
"online": "En ligne",
"onlineUsers": "Utilisateurs en ligne",
"padding_scheme": "Schéma de remplissage",

View File

@ -5,6 +5,8 @@
},
"address": "पता",
"address_placeholder": "सर्वर का पता",
"apiHost": "एपीआई होस्ट",
"apiHostPlaceholder": "http(s)://example.com",
"bandwidth_placeholder": "बैंडविड्थ दर्ज करें, BBR के लिए खाली छोड़ें",
"basic": "बुनियादी कॉन्फ़िगरेशन",
"cancel": "रद्द करें",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "यह क्रिया पूर्ववत नहीं की जा सकती।",
"confirmDeleteTitle": "क्या इस सर्वर को हटाएं?",
"congestion_controller": "भीड़ नियंत्रण",
"connect": "जोड़ें",
"copied": "कॉपी किया गया",
"copy": "कॉपी करें",
"country": "देश",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "जैसे 1-65535",
"host": "होस्ट",
"id": "आईडी",
"installCommand": "इंस्टॉल कमांड",
"ipAddresses": "आईपी पते",
"memory": "मेमोरी",
"migrate": "डेटा माइग्रेट करें",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "अवशोषण पासवर्ड दर्ज करें",
"obfs_path": "ओबफ्स पथ",
"offline": "ऑफलाइन",
"oneClickInstall": "एक-क्लिक इंस्टॉलेशन",
"online": "ऑनलाइन",
"onlineUsers": "ऑनलाइन उपयोगकर्ता",
"padding_scheme": "पैडिंग योजना",

View File

@ -5,6 +5,8 @@
},
"address": "Cím",
"address_placeholder": "Szerver cím",
"apiHost": "API gazda",
"apiHostPlaceholder": "http(s)://pelda.com",
"bandwidth_placeholder": "Adja meg a sávszélességet, hagyja üresen a BBR-hez",
"basic": "Alapértelmezett Beállítások",
"cancel": "Mégse",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "Ez a művelet nem vonható vissza.",
"confirmDeleteTitle": "Törölni szeretné ezt a szervert?",
"congestion_controller": "Torlaszkezelő",
"connect": "Csatlakozás",
"copied": "Másolva",
"copy": "Másolás",
"country": "Ország",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "pl. 1-65535",
"host": "Gazda",
"id": "ID",
"installCommand": "Telepítési parancs",
"ipAddresses": "IP címek",
"memory": "Memória",
"migrate": "Adatok migrálása",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Adja meg az obfuszkálás jelszót",
"obfs_path": "Obfs útvonal",
"offline": "Offline",
"oneClickInstall": "Egylépéses telepítés",
"online": "Online",
"onlineUsers": "Online felhasználók",
"padding_scheme": "Kitöltési Sémák",

View File

@ -5,6 +5,8 @@
},
"address": "アドレス",
"address_placeholder": "サーバーアドレス",
"apiHost": "APIホスト",
"apiHostPlaceholder": "http(s)://example.com",
"bandwidth_placeholder": "帯域幅を入力してください。BBRの場合は空白のままにしてください。",
"basic": "基本設定",
"cancel": "キャンセル",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "この操作は元に戻せません。",
"confirmDeleteTitle": "このサーバーを削除しますか?",
"congestion_controller": "混雑制御",
"connect": "接続",
"copied": "コピーしました",
"copy": "コピー",
"country": "国",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "例: 1-65535",
"host": "ホスト",
"id": "ID",
"installCommand": "インストールコマンド",
"ipAddresses": "IPアドレス",
"memory": "メモリ",
"migrate": "データを移行する",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "難読化パスワードを入力してください",
"obfs_path": "難読化パス",
"offline": "オフライン",
"oneClickInstall": "ワンクリックインストール",
"online": "オンライン",
"onlineUsers": "オンラインユーザー",
"padding_scheme": "パディングスキーム",

View File

@ -5,6 +5,8 @@
},
"address": "주소",
"address_placeholder": "서버 주소",
"apiHost": "API 호스트",
"apiHostPlaceholder": "http(s)://example.com",
"bandwidth_placeholder": "대역폭을 입력하세요. BBR을 사용하려면 비워 두세요.",
"basic": "기본 설정",
"cancel": "취소",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "이 작업은 실행 취소할 수 없습니다.",
"confirmDeleteTitle": "이 서버를 삭제하시겠습니까?",
"congestion_controller": "혼잡 제어기",
"connect": "연결",
"copied": "복사됨",
"copy": "복사",
"country": "국가",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "예: 1-65535",
"host": "호스트",
"id": "ID",
"installCommand": "설치 명령",
"ipAddresses": "IP 주소",
"memory": "메모리",
"migrate": "데이터 마이그레이션",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "난독화 비밀번호를 입력하세요",
"obfs_path": "난독화 경로",
"offline": "오프라인",
"oneClickInstall": "원클릭 설치",
"online": "온라인",
"onlineUsers": "온라인 사용자",
"padding_scheme": "패딩 규칙",

View File

@ -5,6 +5,8 @@
},
"address": "Adresse",
"address_placeholder": "Serveradresse",
"apiHost": "API-vert",
"apiHostPlaceholder": "http(s)://eksempel.com",
"bandwidth_placeholder": "Skriv inn båndbredde, la stå tomt for BBR",
"basic": "Grunnleggende Konfigurasjon",
"cancel": "Avbryt",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "Denne handlingen kan ikke angres.",
"confirmDeleteTitle": "Slette denne serveren?",
"congestion_controller": "Kongestjonskontroller",
"connect": "Koble til",
"copied": "Kopiert",
"copy": "Kopier",
"country": "Land",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "f.eks. 1-65535",
"host": "Vert",
"id": "ID",
"installCommand": "Installasjonskommando",
"ipAddresses": "IP-adresser",
"memory": "Minne",
"migrate": "Migrer data",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Skriv inn obfuskasjonspassord",
"obfs_path": "Obfs Sti",
"offline": "Frakoblet",
"oneClickInstall": "Én-klikk installasjon",
"online": "På nett",
"onlineUsers": "Brukere på nett",
"padding_scheme": "Polstring Skjema",

View File

@ -5,6 +5,8 @@
},
"address": "Adres",
"address_placeholder": "Adres serwera",
"apiHost": "Host API",
"apiHostPlaceholder": "http(s)://przyklad.com",
"bandwidth_placeholder": "Wprowadź przepustowość, pozostaw puste dla BBR",
"basic": "Podstawowa konfiguracja",
"cancel": "Anuluj",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "Ta akcja nie może być cofnięta.",
"confirmDeleteTitle": "Usunąć ten serwer?",
"congestion_controller": "Kontroler przeciążenia",
"connect": "Połącz",
"copied": "Skopiowano",
"copy": "Kopiuj",
"country": "Kraj",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "np. 1-65535",
"host": "Host",
"id": "ID",
"installCommand": "Polecenie instalacji",
"ipAddresses": "Adresy IP",
"memory": "Pamięć",
"migrate": "Migracja danych",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Wprowadź hasło obfuskacji",
"obfs_path": "Ścieżka obfuskacji",
"offline": "Offline",
"oneClickInstall": "Instalacja jednym kliknięciem",
"online": "Online",
"onlineUsers": "Użytkownicy online",
"padding_scheme": "Schemat wypełnienia",

View File

@ -5,6 +5,8 @@
},
"address": "Endereço",
"address_placeholder": "Endereço do servidor",
"apiHost": "Host da API",
"apiHostPlaceholder": "http(s)://exemplo.com",
"bandwidth_placeholder": "Insira a largura de banda, deixe em branco para BBR",
"basic": "Configuração Básica",
"cancel": "Cancelar",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "Esta ação não pode ser desfeita.",
"confirmDeleteTitle": "Excluir este servidor?",
"congestion_controller": "Controlador de congestionamento",
"connect": "Conectar",
"copied": "Copiado",
"copy": "Copiar",
"country": "País",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "ex. 1-65535",
"host": "Host",
"id": "ID",
"installCommand": "Comando de instalação",
"ipAddresses": "Endereços IP",
"memory": "Memória",
"migrate": "Migrar Dados",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Insira a senha de ofuscação",
"obfs_path": "Caminho de Ofuscação",
"offline": "Offline",
"oneClickInstall": "Instalação com um clique",
"online": "Online",
"onlineUsers": "Usuários online",
"padding_scheme": "Esquema de Preenchimento",

View File

@ -5,6 +5,8 @@
},
"address": "Adresă",
"address_placeholder": "Adresă server",
"apiHost": "Gazda API",
"apiHostPlaceholder": "http(s)://exemplu.com",
"bandwidth_placeholder": "Introduceți lățimea de bandă, lăsați liber pentru BBR",
"basic": "Configurare de bază",
"cancel": "Anulează",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "Această acțiune nu poate fi anulată.",
"confirmDeleteTitle": "Șterge acest server?",
"congestion_controller": "Controler de congestie",
"connect": "Conectare",
"copied": "Copiat",
"copy": "Copiază",
"country": "Țară",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "de ex. 1-65535",
"host": "Gazdă",
"id": "ID",
"installCommand": "Comandă de instalare",
"ipAddresses": "Adrese IP",
"memory": "Memorie",
"migrate": "Migrați datele",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Introdu parola de obfuscare",
"obfs_path": "Cale Obfs",
"offline": "Offline",
"oneClickInstall": "Instalare cu un singur clic",
"online": "Online",
"onlineUsers": "Utilizatori online",
"padding_scheme": "Schema de umplere",

View File

@ -5,6 +5,8 @@
},
"address": "Адрес",
"address_placeholder": "Адрес сервера",
"apiHost": "API хост",
"apiHostPlaceholder": "http(s)://пример.ком",
"bandwidth_placeholder": "Введите пропускную способность, оставьте пустым для BBR",
"basic": "Базовая конфигурация",
"cancel": "Отмена",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "Это действие нельзя отменить.",
"confirmDeleteTitle": "Удалить этот сервер?",
"congestion_controller": "Контроллер перегрузки",
"connect": "Подключить",
"copied": "Скопировано",
"copy": "Копировать",
"country": "Страна",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "например, 1-65535",
"host": "Хост",
"id": "ID",
"installCommand": "Команда установки",
"ipAddresses": "IP-адреса",
"memory": "Память",
"migrate": "Перенести данные",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Введите пароль обфускации",
"obfs_path": "Обфусцированный путь",
"offline": "Офлайн",
"oneClickInstall": "Установка в один клик",
"online": "Онлайн",
"onlineUsers": "Онлайн пользователи",
"padding_scheme": "Схема выравнивания",

View File

@ -5,6 +5,8 @@
},
"address": "ที่อยู่",
"address_placeholder": "ที่อยู่เซิร์ฟเวอร์",
"apiHost": "โฮสต์ API",
"apiHostPlaceholder": "http(s)://example.com",
"bandwidth_placeholder": "กรุณากรอกแบนด์วิธ ทิ้งว่างไว้สำหรับ BBR",
"basic": "การตั้งค่าพื้นฐาน",
"cancel": "ยกเลิก",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "การกระทำนี้ไม่สามารถย้อนกลับได้",
"confirmDeleteTitle": "ลบเซิร์ฟเวอร์นี้หรือไม่?",
"congestion_controller": "ตัวควบคุมความแออัด",
"connect": "เชื่อมต่อ",
"copied": "คัดลอกแล้ว",
"copy": "คัดลอก",
"country": "ประเทศ",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "เช่น 1-65535",
"host": "โฮสต์",
"id": "ID",
"installCommand": "คำสั่งติดตั้ง",
"ipAddresses": "ที่อยู่ IP",
"memory": "หน่วยความจำ",
"migrate": "ย้ายข้อมูล",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "กรอกรหัสผ่านการปกปิด",
"obfs_path": "เส้นทางการทำให้ไม่สามารถอ่านได้",
"offline": "ออฟไลน์",
"oneClickInstall": "ติดตั้งด้วยคลิกเดียว",
"online": "ออนไลน์",
"onlineUsers": "ผู้ใช้งานออนไลน์",
"padding_scheme": "รูปแบบการเติม",

View File

@ -5,6 +5,8 @@
},
"address": "Adres",
"address_placeholder": "Sunucu adresi",
"apiHost": "API Sunucusu",
"apiHostPlaceholder": "http(s)://ornek.com",
"bandwidth_placeholder": "Bant genişliğini girin, BBR için boş bırakın",
"basic": "Temel Yapılandırma",
"cancel": "İptal",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "Bu işlem geri alınamaz.",
"confirmDeleteTitle": "Bu sunucuyu silmek istiyor musunuz?",
"congestion_controller": "Tıkanıklık kontrolörü",
"connect": "Bağlan",
"copied": "Kopyalandı",
"copy": "Kopyala",
"country": "Ülke",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "örn. 1-65535",
"host": "Ana bilgisayar",
"id": "ID",
"installCommand": "Kurulum komutu",
"ipAddresses": "IP adresleri",
"memory": "Bellek",
"migrate": "Veri Taşı",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Gizleme şifresini girin",
"obfs_path": "Obfs Yolu",
"offline": "Çevrimdışı",
"oneClickInstall": "Tek Tıkla Kurulum",
"online": "Çevrimiçi",
"onlineUsers": "Çevrimiçi kullanıcılar",
"padding_scheme": "Dolgu Şeması",

View File

@ -5,6 +5,8 @@
},
"address": "Адреса",
"address_placeholder": "Адреса сервера",
"apiHost": "API хост",
"apiHostPlaceholder": "http(s)://example.com",
"bandwidth_placeholder": "Введіть пропускну здатність, залиште порожнім для BBR",
"basic": "Базова конфігурація",
"cancel": "Скасувати",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "Цю дію не можна скасувати.",
"confirmDeleteTitle": "Видалити цей сервер?",
"congestion_controller": "Контролер перевантаження",
"connect": "Підключити",
"copied": "Скопійовано",
"copy": "Копіювати",
"country": "Країна",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "наприклад, 1-65535",
"host": "Хост",
"id": "ID",
"installCommand": "Команда встановлення",
"ipAddresses": "IP адреси",
"memory": "Пам'ять",
"migrate": "Міграція даних",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Введіть пароль обфускації",
"obfs_path": "Обфускаційний шлях",
"offline": "Офлайн",
"oneClickInstall": "Встановлення в один клік",
"online": "Онлайн",
"onlineUsers": "Онлайн користувачі",
"padding_scheme": "Схема заповнення",

View File

@ -5,6 +5,8 @@
},
"address": "Địa chỉ",
"address_placeholder": "Địa chỉ máy chủ",
"apiHost": "Máy chủ API",
"apiHostPlaceholder": "http(s)://example.com",
"bandwidth_placeholder": "Nhập băng thông, để trống cho BBR",
"basic": "Cấu Hình Cơ Bản",
"cancel": "Hủy",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "Hành động này không thể hoàn tác.",
"confirmDeleteTitle": "Xóa máy chủ này?",
"congestion_controller": "Bộ điều khiển tắc nghẽn",
"connect": "Kết nối",
"copied": "Đã sao chép",
"copy": "Sao chép",
"country": "Quốc gia",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "vd. 1-65535",
"host": "Máy chủ",
"id": "ID",
"installCommand": "Lệnh cài đặt",
"ipAddresses": "Địa chỉ IP",
"memory": "Bộ nhớ",
"migrate": "Di chuyển dữ liệu",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "Nhập mật khẩu làm mờ",
"obfs_path": "Đường dẫn Obfs",
"offline": "Ngoại tuyến",
"oneClickInstall": "Cài đặt một lần nhấp",
"online": "Trực tuyến",
"onlineUsers": "Người dùng trực tuyến",
"padding_scheme": "Sơ Đồ Đệm",

View File

@ -5,6 +5,8 @@
},
"address": "地址",
"address_placeholder": "服务器地址",
"apiHost": "API Host",
"apiHostPlaceholder": "http(s)://example.com",
"bandwidth_placeholder": "请输入带宽留空则使用BBR",
"basic": "基础配置",
"cancel": "取消",
@ -13,12 +15,16 @@
"cert_mode": "证书模式",
"cipher": "加密算法",
"city": "城市",
"close": "关闭",
"confirm": "确认",
"confirmDeleteDesc": "该操作不可撤销。",
"confirmDeleteTitle": "确认删除该服务器?",
"congestion_controller": "拥塞控制",
"connect": "对接",
"copied": "已复制",
"copy": "复制",
"copyAndClose": "复制并关闭",
"copyFailed": "复制失败",
"country": "国家",
"cpu": "CPU",
"create": "新建",
@ -52,6 +58,7 @@
"hop_ports_placeholder": "例如 1-65535",
"host": "Host",
"id": "编号",
"installCommand": "一键安装命令",
"ipAddresses": "IP 地址",
"memory": "内存",
"migrate": "迁移数据",
@ -69,6 +76,7 @@
"obfs_password_placeholder": "输入混淆密码",
"obfs_path": "混淆路径",
"offline": "离线",
"oneClickInstall": "一键接入",
"online": "在线",
"onlineUsers": "在线人数",
"padding_scheme": "填充方案",

View File

@ -5,6 +5,8 @@
},
"address": "地址",
"address_placeholder": "伺服器地址",
"apiHost": "API 主機",
"apiHostPlaceholder": "http(s)://example.com",
"bandwidth_placeholder": "輸入帶寬留空以使用BBR",
"basic": "基本配置",
"cancel": "取消",
@ -17,6 +19,7 @@
"confirmDeleteDesc": "此操作無法撤銷。",
"confirmDeleteTitle": "刪除此伺服器?",
"congestion_controller": "擁塞控制器",
"connect": "連接",
"copied": "已複製",
"copy": "複製",
"country": "國家",
@ -52,6 +55,7 @@
"hop_ports_placeholder": "例如 1-65535",
"host": "主機",
"id": "ID",
"installCommand": "安裝命令",
"ipAddresses": "IP 地址",
"memory": "內存",
"migrate": "遷移數據",
@ -69,6 +73,7 @@
"obfs_password_placeholder": "輸入混淆密碼",
"obfs_path": "混淆路徑",
"offline": "離線",
"oneClickInstall": "一鍵安裝",
"online": "在線",
"onlineUsers": "在線用戶",
"padding_scheme": "填充方案",