@garrix82/reactgenie-lib 1.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (85) hide show
  1. package/.env.example +22 -0
  2. package/.github/workflows/publish.yml +20 -0
  3. package/LICENSE.txt +201 -0
  4. package/README.md +621 -0
  5. package/babel.config.js +29 -0
  6. package/dist/adapters/__tests__/expo-router-adapter.test.d.ts +1 -0
  7. package/dist/adapters/expo-router-adapter.d.ts +16 -0
  8. package/dist/adapters/expo-router-adapter.js +521 -0
  9. package/dist/adapters/navigation-adapter.d.ts +20 -0
  10. package/dist/adapters/navigation-adapter.js +137 -0
  11. package/dist/audio-visualizer.d.ts +14 -0
  12. package/dist/audio-visualizer.js +123 -0
  13. package/dist/current-selection.d.ts +27 -0
  14. package/dist/current-selection.js +94 -0
  15. package/dist/errors.d.ts +19 -0
  16. package/dist/errors.js +37 -0
  17. package/dist/genie/DateTime.d.ts +66 -0
  18. package/dist/genie/DateTime.js +399 -0
  19. package/dist/genie/TimeDelta.d.ts +35 -0
  20. package/dist/genie/TimeDelta.js +169 -0
  21. package/dist/genie-view-wrapper.d.ts +1 -0
  22. package/dist/genie-view-wrapper.js +377 -0
  23. package/dist/hooks/__tests__/useSpeechRecognition.test.d.ts +1 -0
  24. package/dist/hooks/useSpeechRecognition.d.ts +28 -0
  25. package/dist/hooks/useSpeechRecognition.js +118 -0
  26. package/dist/index.d.ts +30 -0
  27. package/dist/index.js +469 -0
  28. package/dist/logger.d.ts +23 -0
  29. package/dist/logger.js +597 -0
  30. package/dist/logger.remote.test.d.ts +0 -0
  31. package/dist/modality-provider-v2.d.ts +28 -0
  32. package/dist/modality-provider-v2.js +1321 -0
  33. package/dist/modality-provider.d.ts +22 -0
  34. package/dist/modality-provider.js +373 -0
  35. package/dist/native-visibility.d.ts +28 -0
  36. package/dist/native-visibility.js +50 -0
  37. package/dist/platform/VoiceRecognitionBar.d.ts +17 -0
  38. package/dist/platform/VoiceRecognitionBar.js +332 -0
  39. package/dist/platform/components.d.ts +32 -0
  40. package/dist/platform/components.js +351 -0
  41. package/dist/platform/events.d.ts +31 -0
  42. package/dist/platform/events.js +274 -0
  43. package/dist/platform/index.d.ts +3 -0
  44. package/dist/platform/index.js +39 -0
  45. package/dist/platform/types.d.ts +79 -0
  46. package/dist/platform/types.js +97 -0
  47. package/dist/react-decorators.d.ts +87 -0
  48. package/dist/react-decorators.js +368 -0
  49. package/dist/shared-store.d.ts +74 -0
  50. package/dist/shared-store.js +589 -0
  51. package/dist/speech-recognition/__tests__/speech-recognition-groq-transport.test.d.ts +1 -0
  52. package/dist/speech-recognition/__tests__/speech-recognition-native.test.d.ts +1 -0
  53. package/dist/speech-recognition/__tests__/speech-recognition-openai-native.test.d.ts +1 -0
  54. package/dist/speech-recognition/__tests__/speech-recognition-openai.test.d.ts +1 -0
  55. package/dist/speech-recognition/__tests__/speech-recognition-unified-import.test.d.ts +0 -0
  56. package/dist/speech-recognition/__tests__/speech-recognition-unified.test.d.ts +1 -0
  57. package/dist/speech-recognition/speech-recognition-groq.d.ts +21 -0
  58. package/dist/speech-recognition/speech-recognition-groq.js +409 -0
  59. package/dist/speech-recognition/speech-recognition-mlx.d.ts +15 -0
  60. package/dist/speech-recognition/speech-recognition-mlx.js +393 -0
  61. package/dist/speech-recognition/speech-recognition-native.d.ts +24 -0
  62. package/dist/speech-recognition/speech-recognition-native.js +632 -0
  63. package/dist/speech-recognition/speech-recognition-openai-native.d.ts +40 -0
  64. package/dist/speech-recognition/speech-recognition-openai-native.js +653 -0
  65. package/dist/speech-recognition/speech-recognition-openai.d.ts +39 -0
  66. package/dist/speech-recognition/speech-recognition-openai.js +718 -0
  67. package/dist/speech-recognition/speech-recognition-unified.d.ts +93 -0
  68. package/dist/speech-recognition/speech-recognition-unified.js +589 -0
  69. package/dist/speech-recognition/utils/groq-transcription.d.ts +41 -0
  70. package/dist/speech-recognition/utils/groq-transcription.js +382 -0
  71. package/dist/speech-recognition.d.ts +7 -0
  72. package/dist/speech-recognition.js +61 -0
  73. package/dist/voice-pipeline-telemetry.d.ts +26 -0
  74. package/dist/voice-pipeline-telemetry.js +15 -0
  75. package/garrix82-reactgenie-lib-1.3.0.tgz +0 -0
  76. package/metro/index.js +3 -0
  77. package/metro/with-genie-registry.js +47 -0
  78. package/package.json +111 -0
  79. package/scripts/dry-run.js +23 -0
  80. package/scripts/generate-genie-registry.js +278 -0
  81. package/scripts/log-file-test.js +51 -0
  82. package/scripts/parse.js +26 -0
  83. package/scripts/prompt.js +19 -0
  84. package/scripts/set-script.js +200 -0
  85. package/tsconfig.json +36 -0
@@ -0,0 +1,41 @@
1
+ type ReactNativeFile = {
2
+ uri: string;
3
+ name?: string;
4
+ type?: string;
5
+ };
6
+ export type GroqTranscriptionOptions = {
7
+ apiKey: string;
8
+ audioBlob: Blob | ReactNativeFile;
9
+ mimeType: string;
10
+ language?: string;
11
+ model?: string;
12
+ responseFormat?: 'json' | 'verbose_json';
13
+ stream?: boolean;
14
+ signal?: AbortSignal;
15
+ endpoint?: string;
16
+ onInterim?: (text: string) => void;
17
+ };
18
+ export type GroqTranslationOptions = {
19
+ apiKey: string;
20
+ audioBlob: Blob | ReactNativeFile;
21
+ mimeType: string;
22
+ language?: string;
23
+ model?: string;
24
+ responseFormat?: 'json' | 'verbose_json';
25
+ signal?: AbortSignal;
26
+ endpoint?: string;
27
+ };
28
+ export type GroqTextTranslationOptions = {
29
+ apiKey: string;
30
+ text: string;
31
+ language?: string;
32
+ targetLanguage?: string;
33
+ model?: string;
34
+ signal?: AbortSignal;
35
+ endpoint?: string;
36
+ };
37
+ export declare function streamGroqTranscription({ apiKey, audioBlob, mimeType, language, model, responseFormat, stream, signal, endpoint, onInterim, }: GroqTranscriptionOptions): Promise<string>;
38
+ export declare function translateGroqAudio({ apiKey, audioBlob, mimeType, language, model, responseFormat, signal, endpoint, }: GroqTranslationOptions): Promise<string>;
39
+ export declare function translateGroqText({ apiKey, text, language, targetLanguage, model, signal, endpoint, }: GroqTextTranslationOptions): Promise<string>;
40
+ export declare function mergeTranscriptParts(base: string, addition: string): string;
41
+ export {};
@@ -0,0 +1,382 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.mergeTranscriptParts = mergeTranscriptParts;
7
+ exports.streamGroqTranscription = streamGroqTranscription;
8
+ exports.translateGroqAudio = translateGroqAudio;
9
+ exports.translateGroqText = translateGroqText;
10
+ var _logger = _interopRequireDefault(require("../../logger"));
11
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
12
+ const DEFAULT_ENDPOINT = 'https://api.groq.com/openai/v1/audio/transcriptions';
13
+ const DEFAULT_TRANSLATION_ENDPOINT = 'https://api.groq.com/openai/v1/audio/translations';
14
+ const DEFAULT_CHAT_COMPLETIONS_ENDPOINT = 'https://api.groq.com/openai/v1/chat/completions';
15
+ async function streamGroqTranscription({
16
+ apiKey,
17
+ audioBlob,
18
+ mimeType,
19
+ language = 'en',
20
+ model = 'whisper-large-v3',
21
+ responseFormat = 'verbose_json',
22
+ stream = true,
23
+ signal,
24
+ endpoint = DEFAULT_ENDPOINT,
25
+ onInterim
26
+ }) {
27
+ const fileName = isReactNativeFile(audioBlob) ? audioBlob.name || `audio.${getFileExtension(mimeType)}` : `audio.${getFileExtension(mimeType)}`;
28
+ const formData = new FormData();
29
+ if (isReactNativeFile(audioBlob)) {
30
+ formData.append('file', {
31
+ uri: audioBlob.uri,
32
+ name: fileName,
33
+ type: audioBlob.type || mimeType
34
+ });
35
+ } else {
36
+ const file = createAudioFile(audioBlob, fileName, mimeType);
37
+ if (file && typeof file === 'object') {
38
+ if (file instanceof Blob && !file.name) {
39
+ formData.append('file', file, fileName);
40
+ } else {
41
+ formData.append('file', file);
42
+ }
43
+ }
44
+ }
45
+ formData.append('model', model);
46
+ formData.append('language', language);
47
+ formData.append('response_format', responseFormat);
48
+ const url = stream ? `${endpoint}?stream=true` : endpoint;
49
+ if (stream && isReactNativeEnv() && typeof XMLHttpRequest !== 'undefined') {
50
+ _logger.default.warn('[Groq SSE] using XHR streaming (React Native)');
51
+ return streamGroqTranscriptionViaXhr({
52
+ apiKey,
53
+ formData,
54
+ url,
55
+ signal,
56
+ onInterim
57
+ });
58
+ }
59
+ const response = await fetch(url, {
60
+ method: 'POST',
61
+ headers: {
62
+ Authorization: `Bearer ${apiKey}`
63
+ },
64
+ body: formData,
65
+ signal
66
+ });
67
+ if (!response.ok) {
68
+ const errorBody = await response.text().catch(() => '');
69
+ throw buildHttpError(response.status, errorBody);
70
+ }
71
+ let lastText = '';
72
+ const handleLine = line => {
73
+ const trimmed = line.trim();
74
+ if (!trimmed) return;
75
+ const payload = trimmed.startsWith('data:') ? trimmed.slice(5).trim() : trimmed;
76
+ if (!payload) return;
77
+ try {
78
+ const parsed = JSON.parse(payload);
79
+ const text = extractText(parsed);
80
+ if (text) {
81
+ lastText = text;
82
+ if (onInterim) onInterim(text);
83
+ }
84
+ } catch {
85
+ // ignore non-JSON lines
86
+ }
87
+ };
88
+ const reader = response.body?.getReader?.();
89
+ if (reader && typeof TextDecoder !== 'undefined') {
90
+ const decoder = new TextDecoder();
91
+ let buffer = '';
92
+ while (true) {
93
+ const {
94
+ value,
95
+ done
96
+ } = await reader.read();
97
+ if (done) break;
98
+ buffer += decoder.decode(value, {
99
+ stream: true
100
+ });
101
+ const lines = buffer.split('\n');
102
+ buffer = lines.pop() || '';
103
+ for (const line of lines) {
104
+ handleLine(line);
105
+ }
106
+ }
107
+ if (buffer) {
108
+ handleLine(buffer);
109
+ }
110
+ } else {
111
+ const text = await response.text();
112
+ const lines = text.split('\n');
113
+ for (const line of lines) {
114
+ handleLine(line);
115
+ }
116
+ }
117
+ return lastText;
118
+ }
119
+ async function translateGroqAudio({
120
+ apiKey,
121
+ audioBlob,
122
+ mimeType,
123
+ language,
124
+ model = 'whisper-large-v3',
125
+ responseFormat = 'json',
126
+ signal,
127
+ endpoint = DEFAULT_TRANSLATION_ENDPOINT
128
+ }) {
129
+ const fileName = isReactNativeFile(audioBlob) ? audioBlob.name || `audio.${getFileExtension(mimeType)}` : `audio.${getFileExtension(mimeType)}`;
130
+ const formData = new FormData();
131
+ if (isReactNativeFile(audioBlob)) {
132
+ formData.append('file', {
133
+ uri: audioBlob.uri,
134
+ name: fileName,
135
+ type: audioBlob.type || mimeType
136
+ });
137
+ } else {
138
+ const file = createAudioFile(audioBlob, fileName, mimeType);
139
+ if (file && typeof file === 'object') {
140
+ if (file instanceof Blob && !file.name) {
141
+ formData.append('file', file, fileName);
142
+ } else {
143
+ formData.append('file', file);
144
+ }
145
+ }
146
+ }
147
+ formData.append('model', model);
148
+ if (language) {
149
+ formData.append('language', language);
150
+ }
151
+ formData.append('response_format', responseFormat);
152
+ const response = await fetch(endpoint, {
153
+ method: 'POST',
154
+ headers: {
155
+ Authorization: `Bearer ${apiKey}`
156
+ },
157
+ body: formData,
158
+ signal
159
+ });
160
+ if (!response.ok) {
161
+ const errorBody = await response.text().catch(() => '');
162
+ throw buildHttpError(response.status, errorBody);
163
+ }
164
+ let payload = null;
165
+ try {
166
+ payload = await response.json();
167
+ } catch {
168
+ const text = await response.text().catch(() => '');
169
+ return text.trim();
170
+ }
171
+ return extractText(payload);
172
+ }
173
+ async function translateGroqText({
174
+ apiKey,
175
+ text,
176
+ language,
177
+ targetLanguage = 'English',
178
+ model = 'llama-3.1-8b-instant',
179
+ signal,
180
+ endpoint = DEFAULT_CHAT_COMPLETIONS_ENDPOINT
181
+ }) {
182
+ const input = text.trim();
183
+ if (!input) return '';
184
+ const response = await fetch(endpoint, {
185
+ method: 'POST',
186
+ headers: {
187
+ Authorization: 'Bearer ' + apiKey,
188
+ 'Content-Type': 'application/json'
189
+ },
190
+ body: JSON.stringify({
191
+ model,
192
+ temperature: 0,
193
+ stream: false,
194
+ messages: [{
195
+ role: 'system',
196
+ content: 'Translate user text accurately. Return only translated text without commentary.'
197
+ }, {
198
+ role: 'user',
199
+ content: language ? 'Translate from ' + language + ' to ' + targetLanguage + ': ' + input : 'Translate to ' + targetLanguage + ': ' + input
200
+ }]
201
+ }),
202
+ signal
203
+ });
204
+ if (!response.ok) {
205
+ const errorBody = await response.text().catch(() => '');
206
+ throw buildHttpError(response.status, errorBody);
207
+ }
208
+ const payload = await response.json().catch(() => null);
209
+ const translated = extractChatCompletionText(payload);
210
+ if (translated) return translated.trim();
211
+ return extractText(payload);
212
+ }
213
+ function mergeTranscriptParts(base, addition) {
214
+ const a = base.trim();
215
+ const b = addition.trim();
216
+ if (!a) return b;
217
+ if (!b) return a;
218
+ if (a.endsWith(b)) return a;
219
+ if (b.startsWith(a)) return b;
220
+ return `${a} ${b}`.trim();
221
+ }
222
+ function createAudioFile(audioBlob, name, mimeType) {
223
+ if (typeof File !== 'undefined') {
224
+ try {
225
+ return new File([audioBlob], name, {
226
+ type: mimeType
227
+ });
228
+ } catch {
229
+ return audioBlob;
230
+ }
231
+ }
232
+ return audioBlob;
233
+ }
234
+ function streamGroqTranscriptionViaXhr(options) {
235
+ return new Promise((resolve, reject) => {
236
+ const xhr = new XMLHttpRequest();
237
+ let lastText = '';
238
+ let processedLength = 0;
239
+ let buffer = '';
240
+ const debug = shouldDebugSse();
241
+ const log = debug ? _logger.default.warn : _logger.default.debug;
242
+ const handleLine = line => {
243
+ const trimmed = line.trim();
244
+ if (!trimmed) return;
245
+ const payload = trimmed.startsWith('data:') ? trimmed.slice(5).trim() : trimmed;
246
+ if (!payload) return;
247
+ if (payload === '[DONE]') return;
248
+ try {
249
+ const parsed = JSON.parse(payload);
250
+ const text = extractText(parsed);
251
+ if (text) {
252
+ lastText = text;
253
+ log('[Groq SSE] interim:', text);
254
+ if (options.onInterim) options.onInterim(text);
255
+ }
256
+ } catch {
257
+ // ignore non-JSON lines
258
+ }
259
+ };
260
+ xhr.open('POST', options.url, true);
261
+ xhr.setRequestHeader('Authorization', `Bearer ${options.apiKey}`);
262
+ xhr.responseType = 'text';
263
+ const processIncremental = () => {
264
+ const text = xhr.responseText || '';
265
+ const chunk = text.slice(processedLength);
266
+ if (!chunk) return;
267
+ processedLength = text.length;
268
+ buffer += chunk;
269
+ log('[Groq SSE] chunk bytes:', chunk.length);
270
+ const lines = buffer.split('\n');
271
+ buffer = lines.pop() || '';
272
+ for (const line of lines) {
273
+ handleLine(line);
274
+ }
275
+ };
276
+ xhr.onreadystatechange = () => {
277
+ if (xhr.readyState === XMLHttpRequest.LOADING) {
278
+ processIncremental();
279
+ return;
280
+ }
281
+ if (xhr.readyState === XMLHttpRequest.DONE) {
282
+ if (xhr.status >= 200 && xhr.status < 300) {
283
+ if (buffer) {
284
+ handleLine(buffer);
285
+ buffer = '';
286
+ }
287
+ processIncremental();
288
+ resolve(lastText);
289
+ } else if (xhr.status === 0) {
290
+ // Status 0 in React Native usually means the request never reached the server
291
+ reject(new Error(`Groq API network error (status 0). Check device connectivity, HTTP/ATS cleartext settings, and endpoint URL: ${options.url}`));
292
+ } else {
293
+ reject(buildHttpError(xhr.status, xhr.responseText || ''));
294
+ }
295
+ }
296
+ };
297
+ xhr.onprogress = () => {
298
+ processIncremental();
299
+ };
300
+ xhr.onerror = () => {
301
+ reject(new Error('Groq API network error'));
302
+ };
303
+ if (options.signal) {
304
+ if (options.signal.aborted) {
305
+ xhr.abort();
306
+ reject(new Error('AbortError'));
307
+ return;
308
+ }
309
+ options.signal.addEventListener('abort', () => {
310
+ xhr.abort();
311
+ reject(new Error('AbortError'));
312
+ }, {
313
+ once: true
314
+ });
315
+ }
316
+ xhr.send(options.formData);
317
+ });
318
+ }
319
+ function isReactNativeFile(value) {
320
+ return !!value && typeof value === 'object' && 'uri' in value;
321
+ }
322
+ function isReactNativeEnv() {
323
+ return typeof navigator !== 'undefined' && navigator.product === 'ReactNative';
324
+ }
325
+ function shouldDebugSse() {
326
+ return typeof __DEV__ !== 'undefined' ? __DEV__ : false;
327
+ }
328
+ function extractChatCompletionText(payload) {
329
+ const content = payload?.choices?.[0]?.message?.content;
330
+ if (typeof content === 'string') {
331
+ return content.trim();
332
+ }
333
+ if (Array.isArray(content)) {
334
+ const joined = content.map(part => {
335
+ if (typeof part?.text === 'string') return part.text;
336
+ if (typeof part?.content === 'string') return part.content;
337
+ return '';
338
+ }).join('').trim();
339
+ return joined;
340
+ }
341
+ return '';
342
+ }
343
+ function extractText(payload) {
344
+ if (!payload || typeof payload !== 'object') return '';
345
+ const directText = typeof payload.text === 'string' ? payload.text : '';
346
+ if (directText) return directText.trim();
347
+ const deltaText = payload.delta && typeof payload.delta.text === 'string' ? payload.delta.text : '';
348
+ if (deltaText) return deltaText.trim();
349
+ const dataText = payload.data && typeof payload.data.text === 'string' ? payload.data.text : '';
350
+ if (dataText) return dataText.trim();
351
+ const choiceText = payload.choices?.[0]?.delta?.content || payload.choices?.[0]?.text || '';
352
+ return typeof choiceText === 'string' ? choiceText.trim() : '';
353
+ }
354
+ function buildHttpError(status, rawBody) {
355
+ const detail = extractErrorMessage(rawBody);
356
+ const suffix = detail ? ` - ${detail}` : '';
357
+ return new Error(`Groq API error: ${status}${suffix}`);
358
+ }
359
+ function extractErrorMessage(rawBody) {
360
+ if (!rawBody) return '';
361
+ const trimmed = rawBody.trim();
362
+ if (!trimmed) return '';
363
+ try {
364
+ const parsed = JSON.parse(trimmed);
365
+ const message = parsed?.error?.message || parsed?.error || parsed?.message || parsed?.detail || '';
366
+ if (typeof message === 'string' && message.trim()) {
367
+ return message.trim();
368
+ }
369
+ } catch {
370
+ // ignore JSON parse failures
371
+ }
372
+ return trimmed.slice(0, 300);
373
+ }
374
+ function getFileExtension(mimeType) {
375
+ if (mimeType.includes('webm')) return 'webm';
376
+ if (mimeType.includes('ogg')) return 'ogg';
377
+ if (mimeType.includes('mp4')) return 'mp4';
378
+ if (mimeType.includes('wav')) return 'wav';
379
+ if (mimeType.includes('m4a')) return 'm4a';
380
+ return 'webm';
381
+ }
382
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_logger","_interopRequireDefault","require","e","__esModule","default","DEFAULT_ENDPOINT","DEFAULT_TRANSLATION_ENDPOINT","DEFAULT_CHAT_COMPLETIONS_ENDPOINT","streamGroqTranscription","apiKey","audioBlob","mimeType","language","model","responseFormat","stream","signal","endpoint","onInterim","fileName","isReactNativeFile","name","getFileExtension","formData","FormData","append","uri","type","file","createAudioFile","Blob","url","isReactNativeEnv","XMLHttpRequest","logger","warn","streamGroqTranscriptionViaXhr","response","fetch","method","headers","Authorization","body","ok","errorBody","text","catch","buildHttpError","status","lastText","handleLine","line","trimmed","trim","payload","startsWith","slice","parsed","JSON","parse","extractText","reader","getReader","TextDecoder","decoder","buffer","value","done","read","decode","lines","split","pop","translateGroqAudio","json","translateGroqText","targetLanguage","input","stringify","temperature","messages","role","content","translated","extractChatCompletionText","mergeTranscriptParts","base","addition","a","b","endsWith","File","options","Promise","resolve","reject","xhr","processedLength","debug","shouldDebugSse","log","open","setRequestHeader","responseType","processIncremental","responseText","chunk","length","onreadystatechange","readyState","LOADING","DONE","Error","onprogress","onerror","aborted","abort","addEventListener","once","send","navigator","product","__DEV__","choices","message","Array","isArray","joined","map","part","join","directText","deltaText","delta","dataText","data","choiceText","rawBody","detail","extractErrorMessage","suffix","error","includes"],"sources":["../../../src/speech-recognition/utils/groq-transcription.ts"],"sourcesContent":["import logger from '../../logger';\n\ntype ReactNativeFile = {\n  uri: string;\n  name?: string;\n  type?: string;\n};\n\nexport type GroqTranscriptionOptions = {\n  apiKey: string;\n  audioBlob: Blob | ReactNativeFile;\n  mimeType: string;\n  language?: string;\n  model?: string;\n  responseFormat?: 'json' | 'verbose_json';\n  stream?: boolean;\n  signal?: AbortSignal;\n  endpoint?: string;\n  onInterim?: (text: string) => void;\n};\n\nconst DEFAULT_ENDPOINT = 'https://api.groq.com/openai/v1/audio/transcriptions';\nconst DEFAULT_TRANSLATION_ENDPOINT =\n  'https://api.groq.com/openai/v1/audio/translations';\nconst DEFAULT_CHAT_COMPLETIONS_ENDPOINT =\n  'https://api.groq.com/openai/v1/chat/completions';\n\nexport type GroqTranslationOptions = {\n  apiKey: string;\n  audioBlob: Blob | ReactNativeFile;\n  mimeType: string;\n  language?: string;\n  model?: string;\n  responseFormat?: 'json' | 'verbose_json';\n  signal?: AbortSignal;\n  endpoint?: string;\n};\n\nexport type GroqTextTranslationOptions = {\n  apiKey: string;\n  text: string;\n  language?: string;\n  targetLanguage?: string;\n  model?: string;\n  signal?: AbortSignal;\n  endpoint?: string;\n};\n\nexport async function streamGroqTranscription({\n  apiKey,\n  audioBlob,\n  mimeType,\n  language = 'en',\n  model = 'whisper-large-v3',\n  responseFormat = 'verbose_json',\n  stream = true,\n  signal,\n  endpoint = DEFAULT_ENDPOINT,\n  onInterim,\n}: GroqTranscriptionOptions): Promise<string> {\n  const fileName = isReactNativeFile(audioBlob)\n    ? audioBlob.name || `audio.${getFileExtension(mimeType)}`\n    : `audio.${getFileExtension(mimeType)}`;\n  const formData = new FormData();\n\n  if (isReactNativeFile(audioBlob)) {\n    formData.append('file', {\n      uri: audioBlob.uri,\n      name: fileName,\n      type: audioBlob.type || mimeType,\n    } as any);\n  } else {\n    const file = createAudioFile(audioBlob, fileName, mimeType);\n    if (file && typeof (file as any) === 'object') {\n      if (file instanceof Blob && !(file as any).name) {\n        formData.append('file', file, fileName);\n      } else {\n        formData.append('file', file as any);\n      }\n    }\n  }\n\n  formData.append('model', model);\n  formData.append('language', language);\n  formData.append('response_format', responseFormat);\n\n  const url = stream ? `${endpoint}?stream=true` : endpoint;\n\n  if (stream && isReactNativeEnv() && typeof XMLHttpRequest !== 'undefined') {\n    logger.warn('[Groq SSE] using XHR streaming (React Native)');\n    return streamGroqTranscriptionViaXhr({\n      apiKey,\n      formData,\n      url,\n      signal,\n      onInterim,\n    });\n  }\n\n  const response = await fetch(url, {\n    method: 'POST',\n    headers: {\n      Authorization: `Bearer ${apiKey}`,\n    },\n    body: formData,\n    signal,\n  });\n\n  if (!response.ok) {\n    const errorBody = await response.text().catch(() => '');\n    throw buildHttpError(response.status, errorBody);\n  }\n\n  let lastText = '';\n\n  const handleLine = (line: string) => {\n    const trimmed = line.trim();\n    if (!trimmed) return;\n\n    const payload = trimmed.startsWith('data:') ? trimmed.slice(5).trim() : trimmed;\n    if (!payload) return;\n\n    try {\n      const parsed = JSON.parse(payload);\n      const text = extractText(parsed);\n      if (text) {\n        lastText = text;\n        if (onInterim) onInterim(text);\n      }\n    } catch {\n      // ignore non-JSON lines\n    }\n  };\n\n  const reader = response.body?.getReader?.();\n  if (reader && typeof TextDecoder !== 'undefined') {\n    const decoder = new TextDecoder();\n    let buffer = '';\n\n    while (true) {\n      const { value, done } = await reader.read();\n      if (done) break;\n      buffer += decoder.decode(value, { stream: true });\n      const lines = buffer.split('\\n');\n      buffer = lines.pop() || '';\n      for (const line of lines) {\n        handleLine(line);\n      }\n    }\n\n    if (buffer) {\n      handleLine(buffer);\n    }\n  } else {\n    const text = await response.text();\n    const lines = text.split('\\n');\n    for (const line of lines) {\n      handleLine(line);\n    }\n  }\n\n  return lastText;\n}\n\nexport async function translateGroqAudio({\n  apiKey,\n  audioBlob,\n  mimeType,\n  language,\n  model = 'whisper-large-v3',\n  responseFormat = 'json',\n  signal,\n  endpoint = DEFAULT_TRANSLATION_ENDPOINT,\n}: GroqTranslationOptions): Promise<string> {\n  const fileName = isReactNativeFile(audioBlob)\n    ? audioBlob.name || `audio.${getFileExtension(mimeType)}`\n    : `audio.${getFileExtension(mimeType)}`;\n  const formData = new FormData();\n\n  if (isReactNativeFile(audioBlob)) {\n    formData.append('file', {\n      uri: audioBlob.uri,\n      name: fileName,\n      type: audioBlob.type || mimeType,\n    } as any);\n  } else {\n    const file = createAudioFile(audioBlob, fileName, mimeType);\n    if (file && typeof (file as any) === 'object') {\n      if (file instanceof Blob && !(file as any).name) {\n        formData.append('file', file, fileName);\n      } else {\n        formData.append('file', file as any);\n      }\n    }\n  }\n\n  formData.append('model', model);\n  if (language) {\n    formData.append('language', language);\n  }\n  formData.append('response_format', responseFormat);\n\n  const response = await fetch(endpoint, {\n    method: 'POST',\n    headers: {\n      Authorization: `Bearer ${apiKey}`,\n    },\n    body: formData,\n    signal,\n  });\n\n  if (!response.ok) {\n    const errorBody = await response.text().catch(() => '');\n    throw buildHttpError(response.status, errorBody);\n  }\n\n  let payload: any = null;\n  try {\n    payload = await response.json();\n  } catch {\n    const text = await response.text().catch(() => '');\n    return text.trim();\n  }\n\n  return extractText(payload);\n}\n\nexport async function translateGroqText({\n  apiKey,\n  text,\n  language,\n  targetLanguage = 'English',\n  model = 'llama-3.1-8b-instant',\n  signal,\n  endpoint = DEFAULT_CHAT_COMPLETIONS_ENDPOINT,\n}: GroqTextTranslationOptions): Promise<string> {\n  const input = text.trim();\n  if (!input) return '';\n\n  const response = await fetch(endpoint, {\n    method: 'POST',\n    headers: {\n      Authorization: 'Bearer ' + apiKey,\n      'Content-Type': 'application/json',\n    },\n    body: JSON.stringify({\n      model,\n      temperature: 0,\n      stream: false,\n      messages: [\n        {\n          role: 'system',\n          content:\n            'Translate user text accurately. Return only translated text without commentary.',\n        },\n        {\n          role: 'user',\n          content: language\n            ? 'Translate from ' + language + ' to ' + targetLanguage + ': ' + input\n            : 'Translate to ' + targetLanguage + ': ' + input,\n        },\n      ],\n    }),\n    signal,\n  });\n\n  if (!response.ok) {\n    const errorBody = await response.text().catch(() => '');\n    throw buildHttpError(response.status, errorBody);\n  }\n\n  const payload = await response.json().catch(() => null);\n  const translated = extractChatCompletionText(payload);\n  if (translated) return translated.trim();\n\n  return extractText(payload);\n}\n\nexport function mergeTranscriptParts(base: string, addition: string): string {\n  const a = base.trim();\n  const b = addition.trim();\n  if (!a) return b;\n  if (!b) return a;\n  if (a.endsWith(b)) return a;\n  if (b.startsWith(a)) return b;\n  return `${a} ${b}`.trim();\n}\n\nfunction createAudioFile(audioBlob: Blob, name: string, mimeType: string): Blob | File {\n  if (typeof File !== 'undefined') {\n    try {\n      return new File([audioBlob], name, { type: mimeType });\n    } catch {\n      return audioBlob;\n    }\n  }\n  return audioBlob;\n}\n\nfunction streamGroqTranscriptionViaXhr(options: {\n  apiKey: string;\n  formData: FormData;\n  url: string;\n  signal?: AbortSignal;\n  onInterim?: (text: string) => void;\n}): Promise<string> {\n  return new Promise((resolve, reject) => {\n    const xhr = new XMLHttpRequest();\n    let lastText = '';\n    let processedLength = 0;\n    let buffer = '';\n    const debug = shouldDebugSse();\n    const log = debug ? logger.warn : logger.debug;\n\n    const handleLine = (line: string) => {\n      const trimmed = line.trim();\n      if (!trimmed) return;\n\n      const payload = trimmed.startsWith('data:') ? trimmed.slice(5).trim() : trimmed;\n      if (!payload) return;\n      if (payload === '[DONE]') return;\n\n      try {\n        const parsed = JSON.parse(payload);\n        const text = extractText(parsed);\n        if (text) {\n          lastText = text;\n          log('[Groq SSE] interim:', text);\n          if (options.onInterim) options.onInterim(text);\n        }\n      } catch {\n        // ignore non-JSON lines\n      }\n    };\n\n    xhr.open('POST', options.url, true);\n    xhr.setRequestHeader('Authorization', `Bearer ${options.apiKey}`);\n    xhr.responseType = 'text';\n\n    const processIncremental = () => {\n      const text = xhr.responseText || '';\n      const chunk = text.slice(processedLength);\n      if (!chunk) return;\n      processedLength = text.length;\n      buffer += chunk;\n      log('[Groq SSE] chunk bytes:', chunk.length);\n\n      const lines = buffer.split('\\n');\n      buffer = lines.pop() || '';\n      for (const line of lines) {\n        handleLine(line);\n      }\n    };\n\n    xhr.onreadystatechange = () => {\n      if (xhr.readyState === XMLHttpRequest.LOADING) {\n        processIncremental();\n        return;\n      }\n      if (xhr.readyState === XMLHttpRequest.DONE) {\n        if (xhr.status >= 200 && xhr.status < 300) {\n          if (buffer) {\n            handleLine(buffer);\n            buffer = '';\n          }\n          processIncremental();\n          resolve(lastText);\n        } else if (xhr.status === 0) {\n          // Status 0 in React Native usually means the request never reached the server\n          reject(\n            new Error(\n              `Groq API network error (status 0). Check device connectivity, HTTP/ATS cleartext settings, and endpoint URL: ${options.url}`\n            )\n          );\n        } else {\n          reject(buildHttpError(xhr.status, xhr.responseText || ''));\n        }\n      }\n    };\n\n    xhr.onprogress = () => {\n      processIncremental();\n    };\n\n    xhr.onerror = () => {\n      reject(new Error('Groq API network error'));\n    };\n\n    if (options.signal) {\n      if (options.signal.aborted) {\n        xhr.abort();\n        reject(new Error('AbortError'));\n        return;\n      }\n      options.signal.addEventListener(\n        'abort',\n        () => {\n          xhr.abort();\n          reject(new Error('AbortError'));\n        },\n        { once: true }\n      );\n    }\n\n    xhr.send(options.formData);\n  });\n}\n\nfunction isReactNativeFile(value: Blob | ReactNativeFile): value is ReactNativeFile {\n  return !!value && typeof value === 'object' && 'uri' in value;\n}\n\nfunction isReactNativeEnv(): boolean {\n  return typeof navigator !== 'undefined' && (navigator as any).product === 'ReactNative';\n}\n\nfunction shouldDebugSse(): boolean {\n  return typeof __DEV__ !== 'undefined' ? __DEV__ : false;\n}\n\nfunction extractChatCompletionText(payload: any): string {\n  const content = payload?.choices?.[0]?.message?.content;\n  if (typeof content === 'string') {\n    return content.trim();\n  }\n  if (Array.isArray(content)) {\n    const joined = content\n      .map((part: any) => {\n        if (typeof part?.text === 'string') return part.text;\n        if (typeof part?.content === 'string') return part.content;\n        return '';\n      })\n      .join('')\n      .trim();\n    return joined;\n  }\n  return '';\n}\n\nfunction extractText(payload: any): string {\n  if (!payload || typeof payload !== 'object') return '';\n  const directText = typeof payload.text === 'string' ? payload.text : '';\n  if (directText) return directText.trim();\n\n  const deltaText =\n    payload.delta && typeof payload.delta.text === 'string'\n      ? payload.delta.text\n      : '';\n  if (deltaText) return deltaText.trim();\n\n  const dataText =\n    payload.data && typeof payload.data.text === 'string'\n      ? payload.data.text\n      : '';\n  if (dataText) return dataText.trim();\n\n  const choiceText =\n    payload.choices?.[0]?.delta?.content ||\n    payload.choices?.[0]?.text ||\n    '';\n  return typeof choiceText === 'string' ? choiceText.trim() : '';\n}\n\nfunction buildHttpError(status: number, rawBody?: string): Error {\n  const detail = extractErrorMessage(rawBody);\n  const suffix = detail ? ` - ${detail}` : '';\n  return new Error(`Groq API error: ${status}${suffix}`);\n}\n\nfunction extractErrorMessage(rawBody?: string): string {\n  if (!rawBody) return '';\n  const trimmed = rawBody.trim();\n  if (!trimmed) return '';\n  try {\n    const parsed = JSON.parse(trimmed);\n    const message =\n      parsed?.error?.message ||\n      parsed?.error ||\n      parsed?.message ||\n      parsed?.detail ||\n      '';\n    if (typeof message === 'string' && message.trim()) {\n      return message.trim();\n    }\n  } catch {\n    // ignore JSON parse failures\n  }\n  return trimmed.slice(0, 300);\n}\n\nfunction getFileExtension(mimeType: string): string {\n  if (mimeType.includes('webm')) return 'webm';\n  if (mimeType.includes('ogg')) return 'ogg';\n  if (mimeType.includes('mp4')) return 'mp4';\n  if (mimeType.includes('wav')) return 'wav';\n  if (mimeType.includes('m4a')) return 'm4a';\n  return 'webm';\n}\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,7 @@
1
+ import "regenerator-runtime";
2
+ export declare const SpeechRecognizer: (props: {
3
+ shouldListen: boolean;
4
+ speechStatusCallback: (status: boolean, transcript: string) => void;
5
+ speechResultCallback: (result: string) => void;
6
+ language?: string;
7
+ }) => any;
@@ -0,0 +1,61 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.SpeechRecognizer = void 0;
7
+ require("regenerator-runtime");
8
+ var _reactSpeechRecognition = _interopRequireWildcard(require("react-speech-recognition"));
9
+ var _react = _interopRequireWildcard(require("react"));
10
+ var _reactNative = require("react-native");
11
+ function _interopRequireWildcard(e, t) { if ("function" == typeof WeakMap) var r = new WeakMap(), n = new WeakMap(); return (_interopRequireWildcard = function (e, t) { if (!t && e && e.__esModule) return e; var o, i, f = { __proto__: null, default: e }; if (null === e || "object" != typeof e && "function" != typeof e) return f; if (o = t ? n : r) { if (o.has(e)) return o.get(e); o.set(e, f); } for (const t in e) "default" !== t && {}.hasOwnProperty.call(e, t) && ((i = (o = Object.defineProperty) && Object.getOwnPropertyDescriptor(e, t)) && (i.get || i.set) ? o(f, t, i) : f[t] = e[t]); return f; })(e, t); }
12
+ // import createSpeechServicesPonyfill from "web-speech-cognitive-services";
13
+
14
+ const SpeechRecognizer = props => {
15
+ const {
16
+ finalTranscript,
17
+ interimTranscript,
18
+ resetTranscript,
19
+ listening
20
+ } = (0, _reactSpeechRecognition.useSpeechRecognition)();
21
+ (0, _react.useEffect)(() => {
22
+ if (props.shouldListen && !listening) {
23
+ _reactSpeechRecognition.default.startListening({
24
+ continuous: true,
25
+ interimResults: true,
26
+ language: props.language || "en-US"
27
+ });
28
+ return;
29
+ }
30
+ if (!props.shouldListen && listening) {
31
+ _reactSpeechRecognition.default.stopListening();
32
+ }
33
+ }, [props.shouldListen, props.language, listening]);
34
+ (0, _react.useEffect)(() => {
35
+ props.speechStatusCallback(interimTranscript !== "", interimTranscript);
36
+ }, [interimTranscript, props.speechStatusCallback]);
37
+ (0, _react.useEffect)(() => {
38
+ const trimmedFinal = finalTranscript.trim();
39
+ if (trimmedFinal !== "") {
40
+ props.speechResultCallback(trimmedFinal);
41
+ props.speechStatusCallback(false, "");
42
+ resetTranscript();
43
+ }
44
+ }, [finalTranscript, resetTranscript, props.speechResultCallback, props.speechStatusCallback]);
45
+
46
+ // // initialize Azure speech services by creating a ponyfill
47
+ // useEffect(() => {
48
+ // const { SpeechRecognition: AzureSpeechRecognition } =
49
+ // createSpeechServicesPonyfill({
50
+ // credentials: {
51
+ // region: props.azureSpeechRegion,
52
+ // subscriptionKey: props.azureSpeechKey,
53
+ // },
54
+ // });
55
+ // SpeechRecognition.applyPolyfill(AzureSpeechRecognition);
56
+ // }, []);
57
+
58
+ return /*#__PURE__*/_react.default.createElement(_reactNative.View, null);
59
+ };
60
+ exports.SpeechRecognizer = SpeechRecognizer;
61
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJyZXF1aXJlIiwiX3JlYWN0U3BlZWNoUmVjb2duaXRpb24iLCJfaW50ZXJvcFJlcXVpcmVXaWxkY2FyZCIsIl9yZWFjdCIsIl9yZWFjdE5hdGl2ZSIsImUiLCJ0IiwiV2Vha01hcCIsInIiLCJuIiwiX19lc01vZHVsZSIsIm8iLCJpIiwiZiIsIl9fcHJvdG9fXyIsImRlZmF1bHQiLCJoYXMiLCJnZXQiLCJzZXQiLCJoYXNPd25Qcm9wZXJ0eSIsImNhbGwiLCJPYmplY3QiLCJkZWZpbmVQcm9wZXJ0eSIsImdldE93blByb3BlcnR5RGVzY3JpcHRvciIsIlNwZWVjaFJlY29nbml6ZXIiLCJwcm9wcyIsImZpbmFsVHJhbnNjcmlwdCIsImludGVyaW1UcmFuc2NyaXB0IiwicmVzZXRUcmFuc2NyaXB0IiwibGlzdGVuaW5nIiwidXNlU3BlZWNoUmVjb2duaXRpb24iLCJ1c2VFZmZlY3QiLCJzaG91bGRMaXN0ZW4iLCJTcGVlY2hSZWNvZ25pdGlvbiIsInN0YXJ0TGlzdGVuaW5nIiwiY29udGludW91cyIsImludGVyaW1SZXN1bHRzIiwibGFuZ3VhZ2UiLCJzdG9wTGlzdGVuaW5nIiwic3BlZWNoU3RhdHVzQ2FsbGJhY2siLCJ0cmltbWVkRmluYWwiLCJ0cmltIiwic3BlZWNoUmVzdWx0Q2FsbGJhY2siLCJjcmVhdGVFbGVtZW50IiwiVmlldyIsImV4cG9ydHMiXSwic291cmNlcyI6WyIuLi9zcmMvc3BlZWNoLXJlY29nbml0aW9uLnRzeCJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXCJyZWdlbmVyYXRvci1ydW50aW1lXCI7XG5pbXBvcnQgU3BlZWNoUmVjb2duaXRpb24sIHtcbiAgdXNlU3BlZWNoUmVjb2duaXRpb24sXG59IGZyb20gXCJyZWFjdC1zcGVlY2gtcmVjb2duaXRpb25cIjtcbmltcG9ydCBSZWFjdCwgeyB1c2VFZmZlY3QgfSBmcm9tIFwicmVhY3RcIjtcbmltcG9ydCB7IFZpZXcgfSBmcm9tIFwicmVhY3QtbmF0aXZlXCI7XG4vLyBpbXBvcnQgY3JlYXRlU3BlZWNoU2VydmljZXNQb255ZmlsbCBmcm9tIFwid2ViLXNwZWVjaC1jb2duaXRpdmUtc2VydmljZXNcIjtcblxuZXhwb3J0IGNvbnN0IFNwZWVjaFJlY29nbml6ZXIgPSAocHJvcHM6IHtcbiAgc2hvdWxkTGlzdGVuOiBib29sZWFuO1xuICBzcGVlY2hTdGF0dXNDYWxsYmFjazogKHN0YXR1czogYm9vbGVhbiwgdHJhbnNjcmlwdDogc3RyaW5nKSA9PiB2b2lkO1xuICBzcGVlY2hSZXN1bHRDYWxsYmFjazogKHJlc3VsdDogc3RyaW5nKSA9PiB2b2lkO1xuICBsYW5ndWFnZT86IHN0cmluZztcbiAgLy8gYXp1cmVTcGVlY2hSZWdpb246IHN0cmluZztcbiAgLy8gYXp1cmVTcGVlY2hLZXk6IHN0cmluZztcbn0pID0+IHtcbiAgY29uc3QgeyBmaW5hbFRyYW5zY3JpcHQsIGludGVyaW1UcmFuc2NyaXB0LCByZXNldFRyYW5zY3JpcHQsIGxpc3RlbmluZyB9ID1cbiAgICB1c2VTcGVlY2hSZWNvZ25pdGlvbigpO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgaWYgKHByb3BzLnNob3VsZExpc3RlbiAmJiAhbGlzdGVuaW5nKSB7XG4gICAgICBTcGVlY2hSZWNvZ25pdGlvbi5zdGFydExpc3RlbmluZyh7XG4gICAgICAgIGNvbnRpbnVvdXM6IHRydWUsXG4gICAgICAgIGludGVyaW1SZXN1bHRzOiB0cnVlLFxuICAgICAgICBsYW5ndWFnZTogcHJvcHMubGFuZ3VhZ2UgfHwgXCJlbi1VU1wiLFxuICAgICAgfSk7XG4gICAgICByZXR1cm47XG4gICAgfVxuICAgIGlmICghcHJvcHMuc2hvdWxkTGlzdGVuICYmIGxpc3RlbmluZykge1xuICAgICAgU3BlZWNoUmVjb2duaXRpb24uc3RvcExpc3RlbmluZygpO1xuICAgIH1cbiAgfSwgW3Byb3BzLnNob3VsZExpc3RlbiwgcHJvcHMubGFuZ3VhZ2UsIGxpc3RlbmluZ10pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgcHJvcHMuc3BlZWNoU3RhdHVzQ2FsbGJhY2soaW50ZXJpbVRyYW5zY3JpcHQgIT09IFwiXCIsIGludGVyaW1UcmFuc2NyaXB0KTtcbiAgfSwgW2ludGVyaW1UcmFuc2NyaXB0LCBwcm9wcy5zcGVlY2hTdGF0dXNDYWxsYmFja10pO1xuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgY29uc3QgdHJpbW1lZEZpbmFsID0gZmluYWxUcmFuc2NyaXB0LnRyaW0oKTtcbiAgICBpZiAodHJpbW1lZEZpbmFsICE9PSBcIlwiKSB7XG4gICAgICBwcm9wcy5zcGVlY2hSZXN1bHRDYWxsYmFjayh0cmltbWVkRmluYWwpO1xuICAgICAgcHJvcHMuc3BlZWNoU3RhdHVzQ2FsbGJhY2soZmFsc2UsIFwiXCIpO1xuICAgICAgcmVzZXRUcmFuc2NyaXB0KCk7XG4gICAgfVxuICB9LCBbZmluYWxUcmFuc2NyaXB0LCByZXNldFRyYW5zY3JpcHQsIHByb3BzLnNwZWVjaFJlc3VsdENhbGxiYWNrLCBwcm9wcy5zcGVlY2hTdGF0dXNDYWxsYmFja10pO1xuXG4gIC8vIC8vIGluaXRpYWxpemUgQXp1cmUgc3BlZWNoIHNlcnZpY2VzIGJ5IGNyZWF0aW5nIGEgcG9ueWZpbGxcbiAgLy8gdXNlRWZmZWN0KCgpID0+IHtcbiAgLy8gICBjb25zdCB7IFNwZWVjaFJlY29nbml0aW9uOiBBenVyZVNwZWVjaFJlY29nbml0aW9uIH0gPVxuICAvLyAgICAgY3JlYXRlU3BlZWNoU2VydmljZXNQb255ZmlsbCh7XG4gIC8vICAgICAgIGNyZWRlbnRpYWxzOiB7XG4gIC8vICAgICAgICAgcmVnaW9uOiBwcm9wcy5henVyZVNwZWVjaFJlZ2lvbixcbiAgLy8gICAgICAgICBzdWJzY3JpcHRpb25LZXk6IHByb3BzLmF6dXJlU3BlZWNoS2V5LFxuICAvLyAgICAgICB9LFxuICAvLyAgICAgfSk7XG4gIC8vICAgU3BlZWNoUmVjb2duaXRpb24uYXBwbHlQb2x5ZmlsbChBenVyZVNwZWVjaFJlY29nbml0aW9uKTtcbiAgLy8gfSwgW10pO1xuXG4gIHJldHVybiA8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
@@ -0,0 +1,26 @@
1
+ export type VoicePipelineOutcome = "speech_response_sent" | "speech_response_timeout" | "error" | "aborted";
2
+ export type VoicePipelineStage = "voice.processing" | "stt.listen" | "stt.final_transcript" | "dsl.parse" | "dsl.execute" | "ui.display" | "speech.respond";
3
+ export type VoicePipelineStageStatus = "ok" | "error" | "skipped" | "cancelled";
4
+ export type VoicePipelineContext = {
5
+ sessionId: number;
6
+ threadId?: string | null;
7
+ turnId?: string | null;
8
+ provider?: string;
9
+ language?: string;
10
+ platform?: string;
11
+ };
12
+ export interface VoicePipelineStageHandle {
13
+ annotate?: (context?: Record<string, unknown>) => void;
14
+ finish?: (status: VoicePipelineStageStatus, context?: Record<string, unknown>) => void;
15
+ }
16
+ export interface VoicePipelineHandle {
17
+ annotate?: (context?: Record<string, unknown>) => void;
18
+ getRequestHeaders?: () => Record<string, string | undefined>;
19
+ startStage?: (stage: VoicePipelineStage, context?: Record<string, unknown>) => VoicePipelineStageHandle | null | void;
20
+ finish?: (outcome: VoicePipelineOutcome, context?: Record<string, unknown>) => void;
21
+ }
22
+ export interface VoicePipelineTelemetryBridge {
23
+ startPipeline?: (context: VoicePipelineContext) => VoicePipelineHandle | null | void;
24
+ }
25
+ export declare function setVoicePipelineTelemetryBridge(bridge?: VoicePipelineTelemetryBridge | null): void;
26
+ export declare function getVoicePipelineTelemetryBridge(): VoicePipelineTelemetryBridge | null;
@@ -0,0 +1,15 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.getVoicePipelineTelemetryBridge = getVoicePipelineTelemetryBridge;
7
+ exports.setVoicePipelineTelemetryBridge = setVoicePipelineTelemetryBridge;
8
+ let activeVoicePipelineTelemetryBridge = null;
9
+ function setVoicePipelineTelemetryBridge(bridge) {
10
+ activeVoicePipelineTelemetryBridge = bridge ?? null;
11
+ }
12
+ function getVoicePipelineTelemetryBridge() {
13
+ return activeVoicePipelineTelemetryBridge;
14
+ }
15
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJhY3RpdmVWb2ljZVBpcGVsaW5lVGVsZW1ldHJ5QnJpZGdlIiwic2V0Vm9pY2VQaXBlbGluZVRlbGVtZXRyeUJyaWRnZSIsImJyaWRnZSIsImdldFZvaWNlUGlwZWxpbmVUZWxlbWV0cnlCcmlkZ2UiXSwic291cmNlcyI6WyIuLi9zcmMvdm9pY2UtcGlwZWxpbmUtdGVsZW1ldHJ5LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIFZvaWNlUGlwZWxpbmVPdXRjb21lID1cbiAgfCBcInNwZWVjaF9yZXNwb25zZV9zZW50XCJcbiAgfCBcInNwZWVjaF9yZXNwb25zZV90aW1lb3V0XCJcbiAgfCBcImVycm9yXCJcbiAgfCBcImFib3J0ZWRcIjtcblxuZXhwb3J0IHR5cGUgVm9pY2VQaXBlbGluZVN0YWdlID1cbiAgfCBcInZvaWNlLnByb2Nlc3NpbmdcIlxuICB8IFwic3R0Lmxpc3RlblwiXG4gIHwgXCJzdHQuZmluYWxfdHJhbnNjcmlwdFwiXG4gIHwgXCJkc2wucGFyc2VcIlxuICB8IFwiZHNsLmV4ZWN1dGVcIlxuICB8IFwidWkuZGlzcGxheVwiXG4gIHwgXCJzcGVlY2gucmVzcG9uZFwiO1xuXG5leHBvcnQgdHlwZSBWb2ljZVBpcGVsaW5lU3RhZ2VTdGF0dXMgPSBcIm9rXCIgfCBcImVycm9yXCIgfCBcInNraXBwZWRcIiB8IFwiY2FuY2VsbGVkXCI7XG5cbmV4cG9ydCB0eXBlIFZvaWNlUGlwZWxpbmVDb250ZXh0ID0ge1xuICBzZXNzaW9uSWQ6IG51bWJlcjtcbiAgdGhyZWFkSWQ/OiBzdHJpbmcgfCBudWxsO1xuICB0dXJuSWQ/OiBzdHJpbmcgfCBudWxsO1xuICBwcm92aWRlcj86IHN0cmluZztcbiAgbGFuZ3VhZ2U/OiBzdHJpbmc7XG4gIHBsYXRmb3JtPzogc3RyaW5nO1xufTtcblxuZXhwb3J0IGludGVyZmFjZSBWb2ljZVBpcGVsaW5lU3RhZ2VIYW5kbGUge1xuICBhbm5vdGF0ZT86IChjb250ZXh0PzogUmVjb3JkPHN0cmluZywgdW5rbm93bj4pID0+IHZvaWQ7XG4gIGZpbmlzaD86IChcbiAgICBzdGF0dXM6IFZvaWNlUGlwZWxpbmVTdGFnZVN0YXR1cyxcbiAgICBjb250ZXh0PzogUmVjb3JkPHN0cmluZywgdW5rbm93bj5cbiAgKSA9PiB2b2lkO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIFZvaWNlUGlwZWxpbmVIYW5kbGUge1xuICBhbm5vdGF0ZT86IChjb250ZXh0PzogUmVjb3JkPHN0cmluZywgdW5rbm93bj4pID0+IHZvaWQ7XG4gIGdldFJlcXVlc3RIZWFkZXJzPzogKCkgPT4gUmVjb3JkPHN0cmluZywgc3RyaW5nIHwgdW5kZWZpbmVkPjtcbiAgc3RhcnRTdGFnZT86IChcbiAgICBzdGFnZTogVm9pY2VQaXBlbGluZVN0YWdlLFxuICAgIGNvbnRleHQ/OiBSZWNvcmQ8c3RyaW5nLCB1bmtub3duPlxuICApID0+IFZvaWNlUGlwZWxpbmVTdGFnZUhhbmRsZSB8IG51bGwgfCB2b2lkO1xuICBmaW5pc2g/OiAoXG4gICAgb3V0Y29tZTogVm9pY2VQaXBlbGluZU91dGNvbWUsXG4gICAgY29udGV4dD86IFJlY29yZDxzdHJpbmcsIHVua25vd24+XG4gICkgPT4gdm9pZDtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBWb2ljZVBpcGVsaW5lVGVsZW1ldHJ5QnJpZGdlIHtcbiAgc3RhcnRQaXBlbGluZT86IChcbiAgICBjb250ZXh0OiBWb2ljZVBpcGVsaW5lQ29udGV4dFxuICApID0+IFZvaWNlUGlwZWxpbmVIYW5kbGUgfCBudWxsIHwgdm9pZDtcbn1cblxubGV0IGFjdGl2ZVZvaWNlUGlwZWxpbmVUZWxlbWV0cnlCcmlkZ2U6IFZvaWNlUGlwZWxpbmVUZWxlbWV0cnlCcmlkZ2UgfCBudWxsID0gbnVsbDtcblxuZXhwb3J0IGZ1bmN0aW9uIHNldFZvaWNlUGlwZWxpbmVUZWxlbWV0cnlCcmlkZ2UoXG4gIGJyaWRnZT86IFZvaWNlUGlwZWxpbmVUZWxlbWV0cnlCcmlkZ2UgfCBudWxsXG4pIHtcbiAgYWN0aXZlVm9pY2VQaXBlbGluZVRlbGVtZXRyeUJyaWRnZSA9IGJyaWRnZSA/PyBudWxsO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gZ2V0Vm9pY2VQaXBlbGluZVRlbGVtZXRyeUJyaWRnZSgpOiBWb2ljZVBpcGVsaW5lVGVsZW1ldHJ5QnJpZGdlIHwgbnVsbCB7XG4gIHJldHVybiBhY3RpdmVWb2ljZVBpcGVsaW5lVGVsZW1ldHJ5QnJpZGdlO1xufVxuIl0sIm1hcHBpbmdzIjoiOzs7Ozs7O0FBcURBLElBQUlBLGtDQUF1RSxHQUFHLElBQUk7QUFFM0UsU0FBU0MsK0JBQStCQSxDQUM3Q0MsTUFBNEMsRUFDNUM7RUFDQUYsa0NBQWtDLEdBQUdFLE1BQU0sSUFBSSxJQUFJO0FBQ3JEO0FBRU8sU0FBU0MsK0JBQStCQSxDQUFBLEVBQXdDO0VBQ3JGLE9BQU9ILGtDQUFrQztBQUMzQyIsImlnbm9yZUxpc3QiOltdfQ==
package/metro/index.js ADDED
@@ -0,0 +1,3 @@
1
+ module.exports = {
2
+ withGenieRegistry: require("./with-genie-registry").withGenieRegistry,
3
+ };