feat: add voice playback settings with 4-provider support (#608)

Add WebSpeech, OpenAI TTS, Custom endpoint, and Edge TTS providers.

Co-authored-by: Hermes Agent <noreply@nousresearch.com>
This commit is contained in:
memeflyfly
2026-05-10 20:08:38 +08:00
committed by GitHub
parent 838791a740
commit 15195f0795
18 changed files with 1237 additions and 20 deletions
+51
View File
@@ -511,6 +511,8 @@ jobTriggered: 'Job ausgelost',
session: 'Sitzung',
privacy: 'Datenschutz',
apiServer: 'API-Server',
models: 'Modelle',
voice: 'Sprache',
},
display: {
streaming: 'Streaming-Antworten',
@@ -589,6 +591,55 @@ jobTriggered: 'Job ausgelost',
cors: 'CORS-Ursprunge',
corsHint: 'Erlaubte Cross-Origin-Quellen',
},
voice: {
ttsProvider: 'TTS-Anbieter',
ttsProviderHint: 'Waehlen Sie die Sprachsynthese-Engine fuer die Nachrichtenwiedergabe',
providerWebSpeech: 'WebSpeech API (Browser)',
providerOpenai: 'OpenAI TTS',
providerCustom: 'Benutzerdefinierter Endpunkt (OpenAI-kompatibel)',
providerEdge: 'Edge TTS (Kostenlos, kein API-Key erforderlich)',
// WebSpeech
webspeechVoice: 'Stimme',
webspeechVoiceHint: 'Waehlen Sie eine Stimme aus Ihrem Browser oder Betriebssystem',
webspeechVoicePlaceholder: 'Auto (Standardstimme)',
// OpenAI
openaiKey: 'API-Key',
openaiKeyHint: 'Ihr OpenAI API-Key mit TTS-Zugriff',
openaiUrl: 'API-Basis-URL',
openaiUrlHint: 'z.B. https://api.openai.com/v1/audio/speech',
openaiModel: 'Modell',
openaiModelHint: 'tts-1 (schneller) / tts-1-hd (hoehere Qualitaet)',
openaiVoice: 'Stimme',
openaiVoiceHint: 'Stimme fuer die Synthese',
// Custom endpoint
customHint: 'Jede OpenAI-kompatible TTS-API verwenden — funktioniert mit GPT-SoVITS, CosyVoice, usw.',
customUrl: 'API-URL',
customUrlHint: 'Basis-URL Ihres TTS-Dienstes',
customUrlPlaceholder: 'Die im lokalen Adapter konfigurierte Adresse, z.B. http://127.0.0.1:9880',
customApiKey: 'API-Key (optional)',
customApiKeyHint: 'Einige benutzerdefinierte Endpunkte erfordern Authentifizierung',
customApiKeyPlaceholder: 'Leer lassen wenn nicht benoetigt',
// Edge TTS
edgeHint: 'Angetrieben von Microsoft Edge TTS (node-edge-tts).',
edgeUrl: 'Adapter-URL',
edgeUrlHint: 'Adresse des Edge TTS-Adapters, z.B. http://127.0.0.1:9882',
edgeUrlPlaceholder: 'http://127.0.0.1:9882',
edgeVoice: 'Stimme',
edgeVoiceHint: 'Waehlen Sie eine Stimme fuer die Sprachsynthese',
// Test
testTitle: 'Sprachtest',
testText: 'Testtext',
testTextPlaceholder: 'Text zum Testen eingeben...',
testTextDefault: 'Hallo, dies ist ein Sprachtest.',
testButton: 'Testen',
testButtonPlaying: 'Wiedergabe...',
testFailed: 'Test fehlgeschlagen: {error}',
},
lockedIps: {
title: 'Gesperrte IPs',
count: '{count} gesperrt',
+49
View File
@@ -651,6 +651,7 @@ export default {
privacy: 'Privacy',
apiServer: 'API Server',
models: 'Models',
voice: 'Voice',
},
models: {
apiKey: 'API Key',
@@ -747,6 +748,54 @@ export default {
unlocked: 'IP unlocked',
allUnlocked: '{count} IPs unlocked',
},
voice: {
ttsProvider: 'TTS Provider',
ttsProviderHint: 'Choose the text-to-speech engine for message playback',
providerWebSpeech: 'WebSpeech API (Browser)',
providerOpenai: 'OpenAI TTS',
providerCustom: 'Custom Endpoint (OpenAI-compatible)',
providerEdge: 'Edge TTS (Free, no API Key)',
// WebSpeech
webspeechVoice: 'Voice',
webspeechVoiceHint: 'Select a voice from your browser or OS',
webspeechVoicePlaceholder: 'Auto (default voice)',
// OpenAI
openaiKey: 'API Key',
openaiKeyHint: 'Your OpenAI API key with TTS access',
openaiUrl: 'API Base URL',
openaiUrlHint: 'e.g. https://api.openai.com/v1/audio/speech',
openaiModel: 'Model',
openaiModelHint: 'tts-1 (faster) / tts-1-hd (higher quality)',
openaiVoice: 'Voice',
openaiVoiceHint: 'Voice to use for synthesis',
// Custom endpoint
customHint: 'Use any OpenAI-compatible TTS API — works with GPT-SoVITS, CosyVoice, etc.',
customUrl: 'API URL',
customUrlHint: 'Base URL of your TTS service',
customUrlPlaceholder: 'The address configured in the local adapter, e.g. http://127.0.0.1:9880',
customApiKey: 'API Key (Optional)',
customApiKeyHint: 'Some custom endpoints require authentication',
customApiKeyPlaceholder: 'Leave blank if not needed',
// Edge TTS
edgeHint: 'Powered by Microsoft Edge TTS (node-edge-tts).',
edgeUrl: 'Adapter URL',
edgeUrlHint: 'Address of your Edge TTS adapter, e.g. http://127.0.0.1:9882',
edgeUrlPlaceholder: 'http://127.0.0.1:9882',
edgeVoice: 'Voice',
edgeVoiceHint: 'Select a voice for speech synthesis',
// Test
testTitle: 'Test Voice',
testText: 'Test Text',
testTextPlaceholder: 'Enter text to test...',
testTextDefault: 'Hello, this is a voice test.',
testButton: 'Test',
testButtonPlaying: 'Playing...',
testFailed: 'Test failed: {error}',
},
},
// Platform channel settings
+51
View File
@@ -511,6 +511,8 @@ jobTriggered: 'Job ejecutado',
session: 'Sesion',
privacy: 'Privacidad',
apiServer: 'Servidor API',
models: 'Modelos',
voice: 'Voz',
},
display: {
streaming: 'Respuestas en streaming',
@@ -589,6 +591,55 @@ jobTriggered: 'Job ejecutado',
cors: 'Origenes CORS',
corsHint: 'Fuentes cross-origin permitidas',
},
voice: {
ttsProvider: 'Proveedor TTS',
ttsProviderHint: 'Elija el motor de texto a voz para la reproduccion de mensajes',
providerWebSpeech: 'WebSpeech API (Navegador)',
providerOpenai: 'OpenAI TTS',
providerCustom: 'Endpoint personalizado (compatible con OpenAI)',
providerEdge: 'Edge TTS (Gratuito, sin clave API)',
// WebSpeech
webspeechVoice: 'Voz',
webspeechVoiceHint: 'Seleccione una voz de su navegador o sistema operativo',
webspeechVoicePlaceholder: 'Auto (voz predeterminada)',
// OpenAI
openaiKey: 'Clave API',
openaiKeyHint: 'Su clave API de OpenAI con acceso TTS',
openaiUrl: 'URL base de API',
openaiUrlHint: 'ej. https://api.openai.com/v1/audio/speech',
openaiModel: 'Modelo',
openaiModelHint: 'tts-1 (mas rapido) / tts-1-hd (mayor calidad)',
openaiVoice: 'Voz',
openaiVoiceHint: 'Voz a utilizar para la sintesis',
// Custom endpoint
customHint: 'Utilice cualquier API TTS compatible con OpenAI — funciona con GPT-SoVITS, CosyVoice, etc.',
customUrl: 'URL de API',
customUrlHint: 'URL base de su servicio TTS',
customUrlPlaceholder: 'Direccion configurada en el adaptador local, ej. http://127.0.0.1:9880',
customApiKey: 'Clave API (opcional)',
customApiKeyHint: 'Algunos endpoints personalizados requieren autenticacion',
customApiKeyPlaceholder: 'Dejar en blanco si no es necesario',
// Edge TTS
edgeHint: 'Impulsado por Microsoft Edge TTS (node-edge-tts).',
edgeUrl: 'URL del adaptador',
edgeUrlHint: 'Direccion del adaptador Edge TTS, ej. http://127.0.0.1:9882',
edgeUrlPlaceholder: 'http://127.0.0.1:9882',
edgeVoice: 'Voz',
edgeVoiceHint: 'Seleccione una voz para la sintesis de voz',
// Test
testTitle: 'Prueba de voz',
testText: 'Texto de prueba',
testTextPlaceholder: 'Ingrese texto para probar...',
testTextDefault: 'Hola, esta es una prueba de voz.',
testButton: 'Probar',
testButtonPlaying: 'Reproduciendo...',
testFailed: 'Prueba fallida: {error}',
},
lockedIps: {
title: 'IPs bloqueadas',
count: '{count} bloqueadas',
+51
View File
@@ -511,6 +511,8 @@ jobTriggered: 'Job declenche',
session: 'Session',
privacy: 'Confidentialite',
apiServer: 'Serveur API',
models: 'Modèles',
voice: 'Voix',
},
display: {
streaming: 'Reponses en continu',
@@ -589,6 +591,55 @@ jobTriggered: 'Job declenche',
cors: 'Origines CORS',
corsHint: 'Sources cross-origin autorisees',
},
voice: {
ttsProvider: 'Fournisseur TTS',
ttsProviderHint: 'Choisir le moteur de synthese vocale pour la lecture des messages',
providerWebSpeech: 'WebSpeech API (Navigateur)',
providerOpenai: 'OpenAI TTS',
providerCustom: "Point d'acces personnalise (compatible OpenAI)",
providerEdge: 'Edge TTS (Gratuit, sans cle API)',
// WebSpeech
webspeechVoice: 'Voix',
webspeechVoiceHint: "Choisir une voix depuis le navigateur ou l'OS",
webspeechVoicePlaceholder: 'Auto (voix par defaut)',
// OpenAI
openaiKey: 'Cle API',
openaiKeyHint: 'Votre cle API OpenAI avec acces TTS',
openaiUrl: 'URL de base API',
openaiUrlHint: 'ex. https://api.openai.com/v1/audio/speech',
openaiModel: 'Modele',
openaiModelHint: 'tts-1 (rapide) / tts-1-hd (haute qualite)',
openaiVoice: 'Voix',
openaiVoiceHint: 'Voix a utiliser pour la synthese',
// Custom endpoint
customHint: 'Utilisez toute API TTS compatible OpenAI — fonctionne avec GPT-SoVITS, CosyVoice, etc.',
customUrl: 'URL API',
customUrlHint: 'URL de base de votre service TTS',
customUrlPlaceholder: "Adresse configuree dans l'adaptateur local, ex. http://127.0.0.1:9880",
customApiKey: 'Cle API (optionnelle)',
customApiKeyHint: "Certains points d'acces personnalises necessitent une authentification",
customApiKeyPlaceholder: 'Laisser vide si inutile',
// Edge TTS
edgeHint: 'Propulse par Microsoft Edge TTS (node-edge-tts).',
edgeUrl: "URL de l'adaptateur",
edgeUrlHint: "Adresse de l'adaptateur Edge TTS, ex. http://127.0.0.1:9882",
edgeUrlPlaceholder: 'http://127.0.0.1:9882',
edgeVoice: 'Voix',
edgeVoiceHint: 'Choisir une voix pour la synthese vocale',
// Test
testTitle: 'Test vocal',
testText: 'Texte de test',
testTextPlaceholder: 'Entrez le texte a tester...',
testTextDefault: 'Bonjour, ceci est un test vocal.',
testButton: 'Tester',
testButtonPlaying: 'Lecture...',
testFailed: 'Echec du test : {error}',
},
lockedIps: {
title: 'IPs bloquees',
count: '{count} bloquees',
+51
View File
@@ -511,6 +511,8 @@ export default {
session: 'セッション',
privacy: 'プライバシー',
apiServer: 'API サーバー',
models: 'モデル',
voice: '音声',
},
display: {
streaming: 'ストリームレスポンス',
@@ -589,6 +591,55 @@ export default {
cors: 'CORS 許可元',
corsHint: '許可するクロスオリジン',
},
voice: {
ttsProvider: 'TTS プロバイダー',
ttsProviderHint: 'メッセージ読み上げに使用する音声合成エンジンを選択',
providerWebSpeech: 'WebSpeech API(ブラウザ)',
providerOpenai: 'OpenAI TTS',
providerCustom: 'カスタムエンドポイント(OpenAI 互換)',
providerEdge: 'Edge TTS(無料、API Key 不要)',
// WebSpeech
webspeechVoice: '音声',
webspeechVoiceHint: 'ブラウザまたは OS から音声を選択',
webspeechVoicePlaceholder: '自動(デフォルト音声)',
// OpenAI
openaiKey: 'API キー',
openaiKeyHint: 'TTS アクセス権のある OpenAI API キー',
openaiUrl: 'API ベース URL',
openaiUrlHint: '例: https://api.openai.com/v1/audio/speech',
openaiModel: 'モデル',
openaiModelHint: 'tts-1(高速)/ tts-1-hd(高音質)',
openaiVoice: '音色',
openaiVoiceHint: '合成に使用する音色',
// Custom endpoint
customHint: 'OpenAI 互換の TTS API を使用可能 — GPT-SoVITS、CosyVoice などに対応',
customUrl: 'API URL',
customUrlHint: 'TTS サービスのベース URL',
customUrlPlaceholder: 'ローカルアダプターで設定したアドレス(例:http://127.0.0.1:9880',
customApiKey: 'API キー(オプション)',
customApiKeyHint: '一部のカスタムエンドポイントは認証が必要',
customApiKeyPlaceholder: '不要な場合は空欄',
// Edge TTS
edgeHint: 'Microsoft Edge TTS を搭載(node-edge-tts)。',
edgeUrl: 'アダプター URL',
edgeUrlHint: 'Edge TTS アダプターのアドレス(例:http://127.0.0.1:9882',
edgeUrlPlaceholder: 'http://127.0.0.1:9882',
edgeVoice: '音色',
edgeVoiceHint: '音声合成に使用する音色を選択',
// Test
testTitle: '音声テスト',
testText: 'テストテキスト',
testTextPlaceholder: 'テストするテキストを入力...',
testTextDefault: 'こんにちは、これは音声テストです。',
testButton: 'テスト',
testButtonPlaying: '再生中...',
testFailed: 'テスト失敗:{error}',
},
lockedIps: {
title: 'ロック済みIP管理',
count: '{count}件ロック中',
+51
View File
@@ -511,6 +511,8 @@ export default {
session: '세션',
privacy: '개인정보',
apiServer: 'API 서버',
models: '모델',
voice: '음성',
},
display: {
streaming: '스트리밍 응답',
@@ -589,6 +591,55 @@ export default {
cors: 'CORS 출처',
corsHint: '허용된 교차 출처',
},
voice: {
ttsProvider: 'TTS 제공자',
ttsProviderHint: '메시지 재생에 사용할 텍스트 음성 변환 엔진 선택',
providerWebSpeech: 'WebSpeech API (브라우저)',
providerOpenai: 'OpenAI TTS',
providerCustom: '사용자 정의 엔드포인트 (OpenAI 호환)',
providerEdge: 'Edge TTS (무료, API Key 불필요)',
// WebSpeech
webspeechVoice: '음성',
webspeechVoiceHint: '브라우저 또는 OS에서 음성 선택',
webspeechVoicePlaceholder: '자동 (기본 음성)',
// OpenAI
openaiKey: 'API 키',
openaiKeyHint: 'TTS 접근 권한이 있는 OpenAI API 키',
openaiUrl: 'API 기본 URL',
openaiUrlHint: '예: https://api.openai.com/v1/audio/speech',
openaiModel: '모델',
openaiModelHint: 'tts-1 (빠름) / tts-1-hd (고음질)',
openaiVoice: '음색',
openaiVoiceHint: '합성에 사용할 음색',
// Custom endpoint
customHint: '모든 OpenAI 호환 TTS API 사용 가능 — GPT-SoVITS, CosyVoice 등 지원',
customUrl: 'API URL',
customUrlHint: 'TTS 서비스의 기본 URL',
customUrlPlaceholder: '로컬 어댑터에 설정된 주소 (예: http://127.0.0.1:9880)',
customApiKey: 'API 키 (선택사항)',
customApiKeyHint: '일부 사용자 정의 엔드포인트는 인증 필요',
customApiKeyPlaceholder: '필요하지 않으면 비워둠',
// Edge TTS
edgeHint: 'Microsoft Edge TTS 기반 (node-edge-tts).',
edgeUrl: '어댑터 URL',
edgeUrlHint: 'Edge TTS 어댑터 주소 (예: http://127.0.0.1:9882)',
edgeUrlPlaceholder: 'http://127.0.0.1:9882',
edgeVoice: '음색',
edgeVoiceHint: '음성 합성에 사용할 음색 선택',
// Test
testTitle: '음성 테스트',
testText: '테스트 텍스트',
testTextPlaceholder: '테스트할 텍스트 입력...',
testTextDefault: '안녕하세요, 음성 테스트입니다.',
testButton: '테스트',
testButtonPlaying: '재생 중...',
testFailed: '테스트 실패: {error}',
},
lockedIps: {
title: '잠긴 IP 관리',
count: '{count}개 잠김',
+51
View File
@@ -511,6 +511,8 @@ jobTriggered: 'Job acionado',
session: 'Sessao',
privacy: 'Privacidade',
apiServer: 'Servidor API',
models: 'Modelos',
voice: 'Voz',
},
display: {
streaming: 'Respostas em streaming',
@@ -589,6 +591,55 @@ jobTriggered: 'Job acionado',
cors: 'Origens CORS',
corsHint: 'Fontes cross-origin permitidas',
},
voice: {
ttsProvider: 'Provedor TTS',
ttsProviderHint: 'Escolha o mecanismo de texto para fala para reproducao de mensagens',
providerWebSpeech: 'WebSpeech API (Navegador)',
providerOpenai: 'OpenAI TTS',
providerCustom: 'Endpoint personalizado (compativel com OpenAI)',
providerEdge: 'Edge TTS (Gratuito, sem chave API)',
// WebSpeech
webspeechVoice: 'Voz',
webspeechVoiceHint: 'Selecione uma voz do seu navegador ou SO',
webspeechVoicePlaceholder: 'Auto (voz padrao)',
// OpenAI
openaiKey: 'Chave API',
openaiKeyHint: 'Sua chave API OpenAI com acesso TTS',
openaiUrl: 'URL base da API',
openaiUrlHint: 'ex. https://api.openai.com/v1/audio/speech',
openaiModel: 'Modelo',
openaiModelHint: 'tts-1 (mais rapido) / tts-1-hd (qualidade superior)',
openaiVoice: 'Voz',
openaiVoiceHint: 'Voz a ser usada para sintese',
// Custom endpoint
customHint: 'Use qualquer API TTS compativel com OpenAI — funciona com GPT-SoVITS, CosyVoice, etc.',
customUrl: 'URL da API',
customUrlHint: 'URL base do seu servico TTS',
customUrlPlaceholder: 'Endereco configurado no adaptador local, ex. http://127.0.0.1:9880',
customApiKey: 'Chave API (opcional)',
customApiKeyHint: 'Alguns endpoints personalizados exigem autenticacao',
customApiKeyPlaceholder: 'Deixe em branco se nao for necessario',
// Edge TTS
edgeHint: 'Desenvolvido por Microsoft Edge TTS (node-edge-tts).',
edgeUrl: 'URL do adaptador',
edgeUrlHint: 'Endereco do adaptador Edge TTS, ex. http://127.0.0.1:9882',
edgeUrlPlaceholder: 'http://127.0.0.1:9882',
edgeVoice: 'Voz',
edgeVoiceHint: 'Selecione uma voz para sintese de fala',
// Test
testTitle: 'Teste de voz',
testText: 'Texto de teste',
testTextPlaceholder: 'Insira o texto para testar...',
testTextDefault: 'Ola, este e um teste de voz.',
testButton: 'Testar',
testButtonPlaying: 'Reproduzindo...',
testFailed: 'Teste falhou: {error}',
},
lockedIps: {
title: 'IPs bloqueadas',
count: '{count} bloqueadas',
+49
View File
@@ -643,6 +643,7 @@ export default {
privacy: '隐私',
apiServer: 'API 服务器',
models: '模型',
voice: '语音',
},
models: {
apiKey: 'API Key',
@@ -739,6 +740,54 @@ export default {
unlocked: 'IP 已解锁',
allUnlocked: '已解锁 {count} 个 IP',
},
voice: {
ttsProvider: 'TTS 提供者',
ttsProviderHint: '选择消息朗读使用的语音引擎',
providerWebSpeech: 'WebSpeech API(浏览器内置)',
providerOpenai: 'OpenAI TTS',
providerCustom: '自定义端点(兼容 OpenAI',
providerEdge: 'Edge TTS(免费,无需 API Key',
// WebSpeech
webspeechVoice: '音色',
webspeechVoiceHint: '从浏览器或系统提供的语音中选择',
webspeechVoicePlaceholder: '自动(默认语音)',
// OpenAI
openaiKey: 'API 密钥',
openaiKeyHint: '具有 TTS 权限的 OpenAI API Key',
openaiUrl: 'API 基础地址',
openaiUrlHint: '例如 https://api.openai.com/v1/audio/speech',
openaiModel: '模型',
openaiModelHint: 'tts-1(快速)/ tts-1-hd(高音质)',
openaiVoice: '音色',
openaiVoiceHint: '用于语音合成的音色',
// 自定义端点
customHint: '支持任何 OpenAI 兼容的 TTS 服务——可用于 GPT-SoVITS、CosyVoice 等自部署服务。',
customUrl: 'API 地址',
customUrlHint: 'TTS 服务的完整基础地址',
customUrlPlaceholder: '本地适配器中配置的地址 如:http://127.0.0.1:9880',
customApiKey: 'API 密钥(可选)',
customApiKeyHint: '部分自部署服务需要身份验证',
customApiKeyPlaceholder: '不需要则留空',
// Edge TTS
edgeHint: '由 Microsoft Edge TTS 驱动(node-edge-tts)。',
edgeUrl: '适配器地址',
edgeUrlHint: 'Edge TTS 适配器地址,例如 http://127.0.0.1:9882',
edgeUrlPlaceholder: 'http://127.0.0.1:9882',
edgeVoice: '音色',
edgeVoiceHint: '选择用于语音合成的音色',
// 试听
testTitle: '试听测试',
testText: '测试文本',
testTextPlaceholder: '输入测试文本...',
testTextDefault: '你好,这是一个语音测试。',
testButton: '试听',
testButtonPlaying: '播放中...',
testFailed: '测试失败:{error}',
},
},
// 平台频道设置