cleaned all redundant comments

This commit is contained in:
YunZLu
2025-04-18 03:58:04 +08:00
committed by GitHub
parent d511875db9
commit d7cc70256a

View File

@@ -172,83 +172,66 @@ class SystemTtsProvider {
//#################// //#################//
fetchTtsVoiceObjects() { fetchTtsVoiceObjects() {
if (!('speechSynthesis' in window)) { if (!('speechSynthesis' in window)) {
// Browser doesn't support speech synthesis
return Promise.resolve([]); return Promise.resolve([]);
} }
return new Promise((resolve) => { return new Promise((resolve) => {
// Use a minimal timeout to allow the voice list to potentially populate
setTimeout(() => { setTimeout(() => {
let voices = speechSynthesis.getVoices(); let voices = speechSynthesis.getVoices();
if (voices.length === 0) { if (voices.length === 0) {
// If no voices returned (e.g., Edge on first load), provide a default option // Edge compat: Provide default when voices empty
console.warn('SystemTTS: getVoices() returned empty list. Providing browser default option.'); console.warn('SystemTTS: getVoices() returned empty list. Providing browser default option.');
const defaultVoice = { const defaultVoice = {
name: SystemTtsProvider.BROWSER_DEFAULT_VOICE_NAME, name: SystemTtsProvider.BROWSER_DEFAULT_VOICE_NAME,
voice_id: SystemTtsProvider.BROWSER_DEFAULT_VOICE_ID, voice_id: SystemTtsProvider.BROWSER_DEFAULT_VOICE_ID,
preview_url: false, preview_url: false,
// Try to guess the browser's default language
lang: navigator.language || 'en-US', lang: navigator.language || 'en-US',
}; };
resolve([defaultVoice]); resolve([defaultVoice]);
} else { } else {
// If voices are available, map them as before
const mappedVoices = voices const mappedVoices = voices
.sort((a, b) => a.lang.localeCompare(b.lang) || a.name.localeCompare(b.name)) .sort((a, b) => a.lang.localeCompare(b.lang) || a.name.localeCompare(b.name))
.map(x => ({ name: x.name, voice_id: x.voiceURI, preview_url: false, lang: x.lang })); .map(x => ({ name: x.name, voice_id: x.voiceURI, preview_url: false, lang: x.lang }));
resolve(mappedVoices); resolve(mappedVoices);
} }
}, 50); // Increased timeout slightly just in case it helps voice population on some browsers }, 50);
}); });
} }
previewTtsVoice(voiceId) { previewTtsVoice(voiceId) {
if (!('speechSynthesis' in window)) { if (!('speechSynthesis' in window)) {
throw new Error('Speech synthesis API is not supported'); // Keep Error type for consistency throw new Error('Speech synthesis API is not supported');
} }
let voice = null; let voice = null;
// Check if the requested voice is NOT the browser default
if (voiceId !== SystemTtsProvider.BROWSER_DEFAULT_VOICE_ID) { if (voiceId !== SystemTtsProvider.BROWSER_DEFAULT_VOICE_ID) {
const voices = speechSynthesis.getVoices(); const voices = speechSynthesis.getVoices();
// Try to find the actual voice
voice = voices.find(x => x.voiceURI === voiceId); voice = voices.find(x => x.voiceURI === voiceId);
if (!voice && voices.length > 0) { if (!voice && voices.length > 0) {
// If voices are loaded but the specific ID wasn't found, log a warning
console.warn(`SystemTTS Preview: Voice ID "${voiceId}" not found among available voices. Using browser default.`); console.warn(`SystemTTS Preview: Voice ID "${voiceId}" not found among available voices. Using browser default.`);
// Fallback to default (voice remains null)
} else if (!voice && voices.length === 0) { } else if (!voice && voices.length === 0) {
// If no voices are loaded at all, we expect to use default
console.warn('SystemTTS Preview: Voice list is empty. Using browser default.'); console.warn('SystemTTS Preview: Voice list is empty. Using browser default.');
// Fallback to default (voice remains null)
} }
} else { } else {
console.log('SystemTTS Preview: Using browser default voice as requested.'); console.log('SystemTTS Preview: Using browser default voice as requested.');
// Use default (voice remains null)
} }
speechSynthesis.cancel(); // Stop any previous speech speechSynthesis.cancel();
// Use the language from the found voice if available, otherwise default to 'en-US' or browser lang for the preview text
const langForPreview = voice ? voice.lang : (navigator.language || 'en-US'); const langForPreview = voice ? voice.lang : (navigator.language || 'en-US');
const text = getPreviewString(langForPreview); const text = getPreviewString(langForPreview);
const utterance = new SpeechSynthesisUtterance(text); const utterance = new SpeechSynthesisUtterance(text);
// Only set the voice if we found a specific one and it wasn't the default request
if (voice) { if (voice) {
utterance.voice = voice; utterance.voice = voice;
} }
// Otherwise, utterance.voice remains null/undefined, causing the browser to use its default
utterance.rate = this.settings.rate || 1; utterance.rate = this.settings.rate || 1;
utterance.pitch = this.settings.pitch || 1; utterance.pitch = this.settings.pitch || 1;
// Add error handling for the speech itself
utterance.onerror = (event) => { utterance.onerror = (event) => {
console.error(`SystemTTS Preview Error: ${event.error}`, event); console.error(`SystemTTS Preview Error: ${event.error}`, event);
// Potentially notify the user here
}; };
speechSynthesis.speak(utterance); speechSynthesis.speak(utterance);
@@ -256,11 +239,9 @@ class SystemTtsProvider {
async getVoice(voiceName) { async getVoice(voiceName) {
if (!('speechSynthesis' in window)) { if (!('speechSynthesis' in window)) {
// Return a predictable null-like structure if API not supported
return { voice_id: null, name: 'API Not Supported' }; return { voice_id: null, name: 'API Not Supported' };
} }
// Check if the requested name is the browser default placeholder
if (voiceName === SystemTtsProvider.BROWSER_DEFAULT_VOICE_NAME) { if (voiceName === SystemTtsProvider.BROWSER_DEFAULT_VOICE_NAME) {
return { return {
voice_id: SystemTtsProvider.BROWSER_DEFAULT_VOICE_ID, voice_id: SystemTtsProvider.BROWSER_DEFAULT_VOICE_ID,
@@ -268,16 +249,10 @@ class SystemTtsProvider {
}; };
} }
// Attempt to get voices, might be async
// Note: This relies on voices potentially being populated by now.
// A more robust approach might involve re-calling fetchTtsVoiceObjects if needed,
// but sticking to minimal changes based on original code structure.
const voices = speechSynthesis.getVoices(); const voices = speechSynthesis.getVoices();
if (voices.length === 0) { if (voices.length === 0) {
// If voices are still empty, we can't find any specific name console.warn('SystemTTS: Empty voice list, using default fallback');
console.warn(`SystemTTS getVoice: Voice list empty, cannot find "${voiceName}". Falling back to browser default ID.`);
// Return the default placeholder as a fallback in this edge case
return { return {
voice_id: SystemTtsProvider.BROWSER_DEFAULT_VOICE_ID, voice_id: SystemTtsProvider.BROWSER_DEFAULT_VOICE_ID,
name: SystemTtsProvider.BROWSER_DEFAULT_VOICE_NAME, name: SystemTtsProvider.BROWSER_DEFAULT_VOICE_NAME,
@@ -287,7 +262,6 @@ class SystemTtsProvider {
const match = voices.find(x => x.name == voiceName); const match = voices.find(x => x.name == voiceName);
if (!match) { if (!match) {
// If voices are loaded but name not found, throw error as before
throw new Error(`SystemTTS getVoice: TTS Voice name "${voiceName}" not found`); throw new Error(`SystemTTS getVoice: TTS Voice name "${voiceName}" not found`);
} }
@@ -313,7 +287,6 @@ class SystemTtsProvider {
speechUtteranceChunker(utterance, { speechUtteranceChunker(utterance, {
chunkLength: 200, chunkLength: 200,
}, function () { }, function () {
//some code to execute when done
resolve(silence); resolve(silence);
console.log('System TTS done'); console.log('System TTS done');
}); });