Skip to content

Commit

Permalink
Fail nicely on browsers with no tts support
Browse files Browse the repository at this point in the history
  • Loading branch information
Williangalvani committed Oct 24, 2023
1 parent 545779c commit 21cb191
Showing 1 changed file with 22 additions and 14 deletions.
36 changes: 22 additions & 14 deletions src/stores/alert.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { useStorage } from '@vueuse/core'
import { defineStore } from 'pinia'
import { computed, reactive, watch } from 'vue'
import { computed, reactive, ref, watch } from 'vue'

import { Alert, AlertLevel } from '../types/alert'

Expand Down Expand Up @@ -49,29 +49,37 @@ export const useAlertStore = defineStore('alert', () => {
}

// Alert speech syntesis routine
const synth = window.speechSynthesis
const synth = ref(window.speechSynthesis)

// We need to cache these otherwise they get garbage collected...
let availableAlertSpeechVoiceNames
const utterance_cache: SpeechSynthesisUtterance[] = []
if (synth.value !== undefined) {
synth.value.onvoiceschanged = () => {
synth.value.getVoices().forEach((voice) => {
availableAlertSpeechVoices.push(voice)
if (selectedAlertSpeechVoiceName.value === undefined && voice.default) {
selectedAlertSpeechVoiceName.value = voice.name
}
})
}

synth.onvoiceschanged = () => {
synth.getVoices().forEach((voice) => {
availableAlertSpeechVoices.push(voice)
if (selectedAlertSpeechVoiceName.value === undefined && voice.default) {
selectedAlertSpeechVoiceName.value = voice.name
}
})
availableAlertSpeechVoiceNames = computed(() =>
availableAlertSpeechVoices.map((v) => ({ value: v.name, name: `${v.name} (${v.lang})` }))
)
} else {
availableAlertSpeechVoiceNames = computed(() => [])
}

const availableAlertSpeechVoiceNames = computed(() =>
availableAlertSpeechVoices.map((v) => ({ value: v.name, name: `${v.name} (${v.lang})` }))
)

/**
* Speaks a text out loud using the browsers TTS engine
* @param {string} text string
*/
function speak(text: string): void {
if (!synth.value) {
console.warn('No speechSynthesis available')
return
}
const utterance = new SpeechSynthesisUtterance(text)
const voice = availableAlertSpeechVoices.find((v) => v.name === selectedAlertSpeechVoiceName.value)
if (voice) {
Expand All @@ -85,7 +93,7 @@ export const useAlertStore = defineStore('alert', () => {
utterance.onerror = function (event) {
console.error(`SpeechSynthesisUtterance error: ${event.error}`)
}
synth.speak(utterance)
synth.value.speak(utterance)
}

watch(alerts, () => {
Expand Down

0 comments on commit 21cb191

Please sign in to comment.