UNPKG

@assistant-ui/react

Version:

Typescript/React library for AI Chat

49 lines (42 loc) 1.4 kB
import { SpeechSynthesisAdapter } from "./SpeechAdapterTypes"; export class WebSpeechSynthesisAdapter implements SpeechSynthesisAdapter { speak(text: string): SpeechSynthesisAdapter.Utterance { const utterance = new SpeechSynthesisUtterance(text); const subscribers = new Set<() => void>(); const handleEnd = ( reason: "finished" | "error" | "cancelled", error?: unknown, ) => { if (res.status.type === "ended") return; res.status = { type: "ended", reason, error }; subscribers.forEach((handler) => handler()); }; utterance.addEventListener("end", () => handleEnd("finished")); utterance.addEventListener("error", (e) => handleEnd("error", e.error)); window.speechSynthesis.speak(utterance); const res: SpeechSynthesisAdapter.Utterance = { status: { type: "running" }, cancel: () => { window.speechSynthesis.cancel(); handleEnd("cancelled"); }, subscribe: (callback) => { if (res.status.type === "ended") { let cancelled = false; queueMicrotask(() => { if (!cancelled) callback(); }); return () => { cancelled = true; }; } else { subscribers.add(callback); return () => { subscribers.delete(callback); }; } }, }; return res; } }