react-native-voice-ts 1.0.0 → 1.0.2

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 (41) hide show
  1. package/README.md +914 -83
  2. package/dist/components/MicIcon.d.ts +23 -0
  3. package/dist/components/MicIcon.d.ts.map +1 -0
  4. package/dist/components/MicIcon.js +28 -0
  5. package/dist/components/MicIcon.js.map +1 -0
  6. package/dist/components/VoiceMicrophone.d.ts +93 -0
  7. package/dist/components/VoiceMicrophone.d.ts.map +1 -0
  8. package/dist/components/VoiceMicrophone.js +239 -0
  9. package/dist/components/VoiceMicrophone.js.map +1 -0
  10. package/dist/components/index.d.ts +5 -0
  11. package/dist/components/index.d.ts.map +1 -0
  12. package/dist/components/index.js +3 -0
  13. package/dist/components/index.js.map +1 -0
  14. package/dist/hooks/index.d.ts +3 -0
  15. package/dist/hooks/index.d.ts.map +1 -0
  16. package/dist/hooks/index.js +2 -0
  17. package/dist/hooks/index.js.map +1 -0
  18. package/dist/hooks/useVoiceRecognition.d.ts +89 -0
  19. package/dist/hooks/useVoiceRecognition.d.ts.map +1 -0
  20. package/dist/hooks/useVoiceRecognition.js +227 -0
  21. package/dist/hooks/useVoiceRecognition.js.map +1 -0
  22. package/dist/index.d.ts +4 -0
  23. package/dist/index.d.ts.map +1 -1
  24. package/dist/index.js +4 -0
  25. package/dist/index.js.map +1 -1
  26. package/ios/Voice.xcodeproj/project.xcworkspace/xcuserdata/olumayowadaniel.xcuserdatad/UserInterfaceState.xcuserstate +0 -0
  27. package/ios/Voice.xcodeproj/project.xcworkspace/xcuserdata/rudie_shahinian.xcuserdatad/UserInterfaceState.xcuserstate +0 -0
  28. package/package.json +25 -7
  29. package/plugin/src/withVoice.ts +74 -0
  30. package/plugin/tsconfig.json +10 -0
  31. package/src/components/MicIcon.tsx +72 -0
  32. package/src/components/VoiceMicrophone.tsx +345 -0
  33. package/src/components/index.ts +4 -0
  34. package/src/hooks/index.ts +5 -0
  35. package/src/hooks/useVoiceRecognition.ts +333 -0
  36. package/src/images/mic.svg +16 -0
  37. package/src/index.ts +15 -0
  38. package/.nvmrc +0 -1
  39. package/.prettierrc +0 -5
  40. package/.releaserc +0 -15
  41. package/MIGRATION_SUMMARY.md +0 -510
@@ -0,0 +1,23 @@
1
+ import React from 'react';
2
+ export interface MicIconProps {
3
+ size?: number;
4
+ color?: string;
5
+ strokeWidth?: number;
6
+ }
7
+ /**
8
+ * Microphone Icon Component
9
+ * Based on Lucide mic icon
10
+ */
11
+ export declare const MicIcon: React.FC<MicIconProps>;
12
+ export interface MicOffIconProps {
13
+ size?: number;
14
+ color?: string;
15
+ strokeWidth?: number;
16
+ }
17
+ /**
18
+ * Microphone Off Icon Component
19
+ * For recording/stop state
20
+ */
21
+ export declare const MicOffIcon: React.FC<MicOffIconProps>;
22
+ export default MicIcon;
23
+ //# sourceMappingURL=MicIcon.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MicIcon.d.ts","sourceRoot":"","sources":["../../src/components/MicIcon.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,MAAM,WAAW,YAAY;IAC3B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED;;;GAGG;AACH,eAAO,MAAM,OAAO,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAqB1C,CAAC;AAEF,MAAM,WAAW,eAAe;IAC9B,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED;;;GAGG;AACH,eAAO,MAAM,UAAU,EAAE,KAAK,CAAC,EAAE,CAAC,eAAe,CAuBhD,CAAC;AAEF,eAAe,OAAO,CAAC"}
@@ -0,0 +1,28 @@
1
+ import React from 'react';
2
+ import Svg, { Path, Rect } from 'react-native-svg';
3
+ /**
4
+ * Microphone Icon Component
5
+ * Based on Lucide mic icon
6
+ */
7
+ export const MicIcon = ({ size = 24, color = 'currentColor', strokeWidth = 2, }) => {
8
+ return (<Svg width={size} height={size} viewBox="0 0 24 24" fill="none" stroke={color} strokeWidth={strokeWidth} strokeLinecap="round" strokeLinejoin="round">
9
+ <Path d="M12 19v3"/>
10
+ <Path d="M19 10v2a7 7 0 0 1-14 0v-2"/>
11
+ <Rect x="9" y="2" width="6" height="13" rx="3"/>
12
+ </Svg>);
13
+ };
14
+ /**
15
+ * Microphone Off Icon Component
16
+ * For recording/stop state
17
+ */
18
+ export const MicOffIcon = ({ size = 24, color = 'currentColor', strokeWidth = 2, }) => {
19
+ return (<Svg width={size} height={size} viewBox="0 0 24 24" fill="none" stroke={color} strokeWidth={strokeWidth} strokeLinecap="round" strokeLinejoin="round">
20
+ <Path d="M2 2l20 20"/>
21
+ <Path d="M12 12a3 3 0 0 0 3-3V5a3 3 0 1 0-6 0v1"/>
22
+ <Path d="M19 10v2a7 7 0 0 1-11.18 5.66"/>
23
+ <Path d="M4.27 16.73A7 7 0 0 1 5 12v-2"/>
24
+ <Path d="M12 17v5"/>
25
+ </Svg>);
26
+ };
27
+ export default MicIcon;
28
+ //# sourceMappingURL=MicIcon.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"MicIcon.js","sourceRoot":"","sources":["../../src/components/MicIcon.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,GAAG,EAAE,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,kBAAkB,CAAC;AAQnD;;;GAGG;AACH,MAAM,CAAC,MAAM,OAAO,GAA2B,CAAC,EAC9C,IAAI,GAAG,EAAE,EACT,KAAK,GAAG,cAAc,EACtB,WAAW,GAAG,CAAC,GAChB,EAAE,EAAE;IACH,OAAO,CACL,CAAC,GAAG,CACF,KAAK,CAAC,CAAC,IAAI,CAAC,CACZ,MAAM,CAAC,CAAC,IAAI,CAAC,CACb,OAAO,CAAC,WAAW,CACnB,IAAI,CAAC,MAAM,CACX,MAAM,CAAC,CAAC,KAAK,CAAC,CACd,WAAW,CAAC,CAAC,WAAW,CAAC,CACzB,aAAa,CAAC,OAAO,CACrB,cAAc,CAAC,OAAO,CAEtB;MAAA,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,EAClB;MAAA,CAAC,IAAI,CAAC,CAAC,CAAC,4BAA4B,EACpC;MAAA,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,GAAG,EAChD;IAAA,EAAE,GAAG,CAAC,CACP,CAAC;AACJ,CAAC,CAAC;AAQF;;;GAGG;AACH,MAAM,CAAC,MAAM,UAAU,GAA8B,CAAC,EACpD,IAAI,GAAG,EAAE,EACT,KAAK,GAAG,cAAc,EACtB,WAAW,GAAG,CAAC,GAChB,EAAE,EAAE;IACH,OAAO,CACL,CAAC,GAAG,CACF,KAAK,CAAC,CAAC,IAAI,CAAC,CACZ,MAAM,CAAC,CAAC,IAAI,CAAC,CACb,OAAO,CAAC,WAAW,CACnB,IAAI,CAAC,MAAM,CACX,MAAM,CAAC,CAAC,KAAK,CAAC,CACd,WAAW,CAAC,CAAC,WAAW,CAAC,CACzB,aAAa,CAAC,OAAO,CACrB,cAAc,CAAC,OAAO,CAEtB;MAAA,CAAC,IAAI,CAAC,CAAC,CAAC,YAAY,EACpB;MAAA,CAAC,IAAI,CAAC,CAAC,CAAC,wCAAwC,EAChD;MAAA,CAAC,IAAI,CAAC,CAAC,CAAC,+BAA+B,EACvC;MAAA,CAAC,IAAI,CAAC,CAAC,CAAC,+BAA+B,EACvC;MAAA,CAAC,IAAI,CAAC,CAAC,CAAC,UAAU,EACpB;IAAA,EAAE,GAAG,CAAC,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,OAAO,CAAC"}
@@ -0,0 +1,93 @@
1
+ import React from 'react';
2
+ export interface VoiceMicrophoneProps {
3
+ /**
4
+ * Callback fired when speech is recognized and converted to text
5
+ */
6
+ onSpeechResult?: (text: string) => void;
7
+ /**
8
+ * Callback fired when partial results are available (real-time)
9
+ */
10
+ onPartialResult?: (text: string) => void;
11
+ /**
12
+ * Callback fired when recording starts
13
+ */
14
+ onStart?: () => void;
15
+ /**
16
+ * Callback fired when recording stops
17
+ */
18
+ onStop?: () => void;
19
+ /**
20
+ * Callback fired when an error occurs
21
+ */
22
+ onError?: (error: string) => void;
23
+ /**
24
+ * Language locale for speech recognition
25
+ * @default 'en-US'
26
+ */
27
+ locale?: string;
28
+ /**
29
+ * Whether to automatically start recording on mount
30
+ * @default false
31
+ */
32
+ autoStart?: boolean;
33
+ /**
34
+ * Whether to enable partial results (real-time transcription)
35
+ * @default true
36
+ */
37
+ enablePartialResults?: boolean;
38
+ /**
39
+ * Whether to continue listening after getting results (continuous mode)
40
+ * When enabled, the microphone will automatically restart after getting results
41
+ * @default false
42
+ */
43
+ continuous?: boolean;
44
+ /**
45
+ * Maximum silence duration in milliseconds before stopping (continuous mode)
46
+ * Only applies when continuous mode is enabled
47
+ * @default 5000 (5 seconds)
48
+ */
49
+ maxSilenceDuration?: number;
50
+ /**
51
+ * Custom render function for the component
52
+ * Receives isRecording state and control functions
53
+ */
54
+ children?: (props: {
55
+ isRecording: boolean;
56
+ recognizedText: string;
57
+ partialText: string;
58
+ start: () => Promise<void>;
59
+ stop: () => Promise<void>;
60
+ cancel: () => Promise<void>;
61
+ error: string | null;
62
+ }) => React.ReactNode;
63
+ }
64
+ /**
65
+ * VoiceMicrophone Component
66
+ *
67
+ * A ready-to-use voice recognition component that handles microphone access,
68
+ * speech recognition, and provides real-time text results.
69
+ *
70
+ * @example
71
+ * ```tsx
72
+ * // Simple usage with callback
73
+ * <VoiceMicrophone
74
+ * onSpeechResult={(text) => setSearchQuery(text)}
75
+ * />
76
+ *
77
+ * // Custom render with full control
78
+ * <VoiceMicrophone locale="en-US">
79
+ * {({ isRecording, recognizedText, start, stop }) => (
80
+ * <View>
81
+ * <Text>{recognizedText}</Text>
82
+ * <Button
83
+ * onPress={isRecording ? stop : start}
84
+ * title={isRecording ? 'Stop' : 'Start'}
85
+ * />
86
+ * </View>
87
+ * )}
88
+ * </VoiceMicrophone>
89
+ * ```
90
+ */
91
+ declare const VoiceMicrophone: React.FC<VoiceMicrophoneProps>;
92
+ export default VoiceMicrophone;
93
+ //# sourceMappingURL=VoiceMicrophone.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"VoiceMicrophone.d.ts","sourceRoot":"","sources":["../../src/components/VoiceMicrophone.tsx"],"names":[],"mappings":"AAAA,OAAO,KAA2C,MAAM,OAAO,CAAC;AAIhE,MAAM,WAAW,oBAAoB;IACnC;;OAEG;IACH,cAAc,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAExC;;OAEG;IACH,eAAe,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAEzC;;OAEG;IACH,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IAErB;;OAEG;IACH,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;IAEpB;;OAEG;IACH,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IAElC;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB;;;OAGG;IACH,SAAS,CAAC,EAAE,OAAO,CAAC;IAEpB;;;OAGG;IACH,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAE/B;;;;OAIG;IACH,UAAU,CAAC,EAAE,OAAO,CAAC;IAErB;;;;OAIG;IACH,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAE5B;;;OAGG;IACH,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE;QACjB,WAAW,EAAE,OAAO,CAAC;QACrB,cAAc,EAAE,MAAM,CAAC;QACvB,WAAW,EAAE,MAAM,CAAC;QACpB,KAAK,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;QAC3B,IAAI,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;QAC1B,MAAM,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;QAC5B,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;KACtB,KAAK,KAAK,CAAC,SAAS,CAAC;CACvB;AAED;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BG;AACH,QAAA,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC,oBAAoB,CA8OnD,CAAC;AAEF,eAAe,eAAe,CAAC"}
@@ -0,0 +1,239 @@
1
+ import React, { useEffect, useState, useCallback } from 'react';
2
+ import Voice from '../index';
3
+ /**
4
+ * VoiceMicrophone Component
5
+ *
6
+ * A ready-to-use voice recognition component that handles microphone access,
7
+ * speech recognition, and provides real-time text results.
8
+ *
9
+ * @example
10
+ * ```tsx
11
+ * // Simple usage with callback
12
+ * <VoiceMicrophone
13
+ * onSpeechResult={(text) => setSearchQuery(text)}
14
+ * />
15
+ *
16
+ * // Custom render with full control
17
+ * <VoiceMicrophone locale="en-US">
18
+ * {({ isRecording, recognizedText, start, stop }) => (
19
+ * <View>
20
+ * <Text>{recognizedText}</Text>
21
+ * <Button
22
+ * onPress={isRecording ? stop : start}
23
+ * title={isRecording ? 'Stop' : 'Start'}
24
+ * />
25
+ * </View>
26
+ * )}
27
+ * </VoiceMicrophone>
28
+ * ```
29
+ */
30
+ const VoiceMicrophone = ({ onSpeechResult, onPartialResult, onStart, onStop, onError, locale = 'en-US', autoStart = false, enablePartialResults = true, continuous = false, maxSilenceDuration = 5000, children, }) => {
31
+ const [isRecording, setIsRecording] = useState(false);
32
+ const [recognizedText, setRecognizedText] = useState('');
33
+ const [partialText, setPartialText] = useState('');
34
+ const [error, setError] = useState(null);
35
+ const [shouldContinue, setShouldContinue] = useState(false);
36
+ const silenceTimerRef = React.useRef(null);
37
+ useEffect(() => {
38
+ // Clear any existing timers on cleanup
39
+ return () => {
40
+ if (silenceTimerRef.current) {
41
+ clearTimeout(silenceTimerRef.current);
42
+ }
43
+ };
44
+ }, []);
45
+ useEffect(() => {
46
+ // Set up event listeners
47
+ Voice.onSpeechStart = () => {
48
+ setIsRecording(true);
49
+ setError(null);
50
+ if (silenceTimerRef.current) {
51
+ clearTimeout(silenceTimerRef.current);
52
+ }
53
+ onStart?.();
54
+ };
55
+ Voice.onSpeechEnd = async () => {
56
+ setIsRecording(false);
57
+ // In continuous mode, restart listening after results
58
+ if (continuous && shouldContinue) {
59
+ // Small delay before restarting
60
+ setTimeout(async () => {
61
+ if (shouldContinue) {
62
+ try {
63
+ await Voice.start(locale, {
64
+ EXTRA_PARTIAL_RESULTS: enablePartialResults,
65
+ });
66
+ }
67
+ catch (err) {
68
+ console.error('Failed to restart voice recognition:', err);
69
+ }
70
+ }
71
+ }, 100);
72
+ }
73
+ else {
74
+ onStop?.();
75
+ }
76
+ };
77
+ Voice.onSpeechError = (e) => {
78
+ const errorMessage = e.error?.message || 'Unknown error';
79
+ setError(errorMessage);
80
+ setIsRecording(false);
81
+ setShouldContinue(false);
82
+ if (silenceTimerRef.current) {
83
+ clearTimeout(silenceTimerRef.current);
84
+ }
85
+ onError?.(errorMessage);
86
+ };
87
+ Voice.onSpeechResults = (e) => {
88
+ if (e.value && e.value.length > 0) {
89
+ const text = e.value[0];
90
+ // In continuous mode, append new text to existing
91
+ if (continuous && recognizedText) {
92
+ const updatedText = recognizedText + ' ' + text;
93
+ setRecognizedText(updatedText);
94
+ onSpeechResult?.(updatedText);
95
+ }
96
+ else {
97
+ setRecognizedText(text);
98
+ onSpeechResult?.(text);
99
+ }
100
+ setPartialText('');
101
+ }
102
+ };
103
+ if (enablePartialResults) {
104
+ Voice.onSpeechPartialResults = (e) => {
105
+ if (e.value && e.value.length > 0) {
106
+ const text = e.value[0];
107
+ setPartialText(text);
108
+ onPartialResult?.(text);
109
+ // Reset silence timer on partial results (user is speaking)
110
+ if (continuous && silenceTimerRef.current) {
111
+ clearTimeout(silenceTimerRef.current);
112
+ silenceTimerRef.current = setTimeout(() => {
113
+ if (shouldContinue) {
114
+ stop();
115
+ }
116
+ }, maxSilenceDuration);
117
+ }
118
+ }
119
+ };
120
+ }
121
+ // Cleanup
122
+ return () => {
123
+ Voice.destroy().then(Voice.removeAllListeners);
124
+ };
125
+ }, [
126
+ onSpeechResult,
127
+ onPartialResult,
128
+ onStart,
129
+ onStop,
130
+ onError,
131
+ enablePartialResults,
132
+ continuous,
133
+ shouldContinue,
134
+ recognizedText,
135
+ locale,
136
+ maxSilenceDuration,
137
+ ]);
138
+ // Auto-start if enabled
139
+ useEffect(() => {
140
+ if (autoStart) {
141
+ start();
142
+ }
143
+ // eslint-disable-next-line react-hooks/exhaustive-deps
144
+ }, [autoStart]);
145
+ const start = useCallback(async () => {
146
+ try {
147
+ setError(null);
148
+ if (!continuous) {
149
+ setRecognizedText('');
150
+ setPartialText('');
151
+ }
152
+ setShouldContinue(true);
153
+ // Check permission (Android only)
154
+ const hasPermission = await Voice.checkMicrophonePermission();
155
+ if (!hasPermission) {
156
+ const granted = await Voice.requestMicrophonePermission();
157
+ if (!granted) {
158
+ setError('Microphone permission denied');
159
+ return;
160
+ }
161
+ }
162
+ await Voice.start(locale, {
163
+ EXTRA_PARTIAL_RESULTS: enablePartialResults,
164
+ });
165
+ // Start silence timer if in continuous mode
166
+ if (continuous) {
167
+ silenceTimerRef.current = setTimeout(() => {
168
+ if (shouldContinue) {
169
+ stop();
170
+ }
171
+ }, maxSilenceDuration);
172
+ }
173
+ }
174
+ catch (e) {
175
+ const errorMessage = e instanceof Error ? e.message : 'Failed to start recording';
176
+ setError(errorMessage);
177
+ setShouldContinue(false);
178
+ onError?.(errorMessage);
179
+ }
180
+ }, [
181
+ locale,
182
+ enablePartialResults,
183
+ onError,
184
+ continuous,
185
+ maxSilenceDuration,
186
+ shouldContinue,
187
+ ]);
188
+ const stop = useCallback(async () => {
189
+ try {
190
+ setShouldContinue(false);
191
+ if (silenceTimerRef.current) {
192
+ clearTimeout(silenceTimerRef.current);
193
+ silenceTimerRef.current = null;
194
+ }
195
+ await Voice.stop();
196
+ onStop?.();
197
+ }
198
+ catch (e) {
199
+ const errorMessage = e instanceof Error ? e.message : 'Failed to stop recording';
200
+ setError(errorMessage);
201
+ onError?.(errorMessage);
202
+ }
203
+ }, [onError, onStop]);
204
+ const cancel = useCallback(async () => {
205
+ try {
206
+ setShouldContinue(false);
207
+ if (silenceTimerRef.current) {
208
+ clearTimeout(silenceTimerRef.current);
209
+ silenceTimerRef.current = null;
210
+ }
211
+ await Voice.cancel();
212
+ setRecognizedText('');
213
+ setPartialText('');
214
+ }
215
+ catch (e) {
216
+ const errorMessage = e instanceof Error ? e.message : 'Failed to cancel recording';
217
+ setError(errorMessage);
218
+ onError?.(errorMessage);
219
+ }
220
+ }, [onError]);
221
+ // If children render prop is provided, use it
222
+ if (children) {
223
+ return (<>
224
+ {children({
225
+ isRecording,
226
+ recognizedText,
227
+ partialText,
228
+ start,
229
+ stop,
230
+ cancel,
231
+ error,
232
+ })}
233
+ </>);
234
+ }
235
+ // Default: render nothing (headless component)
236
+ return null;
237
+ };
238
+ export default VoiceMicrophone;
239
+ //# sourceMappingURL=VoiceMicrophone.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"VoiceMicrophone.js","sourceRoot":"","sources":["../../src/components/VoiceMicrophone.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ export { default as VoiceMicrophone } from './VoiceMicrophone';
2
+ export type { VoiceMicrophoneProps } from './VoiceMicrophone';
3
+ export { MicIcon, MicOffIcon } from './MicIcon';
4
+ export type { MicIconProps, MicOffIconProps } from './MicIcon';
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/components/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAC/D,YAAY,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAC9D,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC;AAChD,YAAY,EAAE,YAAY,EAAE,eAAe,EAAE,MAAM,WAAW,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { default as VoiceMicrophone } from './VoiceMicrophone';
2
+ export { MicIcon, MicOffIcon } from './MicIcon';
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/components/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,IAAI,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAE/D,OAAO,EAAE,OAAO,EAAE,UAAU,EAAE,MAAM,WAAW,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { useVoiceRecognition } from './useVoiceRecognition';
2
+ export type { UseVoiceRecognitionOptions, UseVoiceRecognitionReturn, } from './useVoiceRecognition';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,YAAY,EACV,0BAA0B,EAC1B,yBAAyB,GAC1B,MAAM,uBAAuB,CAAC"}
@@ -0,0 +1,2 @@
1
+ export { useVoiceRecognition } from './useVoiceRecognition';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/hooks/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC"}
@@ -0,0 +1,89 @@
1
+ export interface UseVoiceRecognitionOptions {
2
+ /**
3
+ * Language locale for speech recognition
4
+ * @default 'en-US'
5
+ */
6
+ locale?: string;
7
+ /**
8
+ * Whether to enable partial results (real-time transcription)
9
+ * @default true
10
+ */
11
+ enablePartialResults?: boolean;
12
+ /**
13
+ * Whether to continue listening after getting results (continuous mode)
14
+ * When enabled, the microphone will automatically restart after getting results
15
+ * @default false
16
+ */
17
+ continuous?: boolean;
18
+ /**
19
+ * Maximum silence duration in milliseconds before stopping (continuous mode)
20
+ * Only applies when continuous mode is enabled
21
+ * @default 5000 (5 seconds)
22
+ */
23
+ maxSilenceDuration?: number;
24
+ /**
25
+ * Callback fired when speech is recognized
26
+ */
27
+ onResult?: (text: string) => void;
28
+ /**
29
+ * Callback fired when an error occurs
30
+ */
31
+ onError?: (error: string) => void;
32
+ }
33
+ export interface UseVoiceRecognitionReturn {
34
+ /**
35
+ * Whether voice recognition is currently active
36
+ */
37
+ isRecording: boolean;
38
+ /**
39
+ * Final recognized text results
40
+ */
41
+ results: string[];
42
+ /**
43
+ * Partial results (real-time transcription)
44
+ */
45
+ partialResults: string[];
46
+ /**
47
+ * Error message if an error occurred
48
+ */
49
+ error: string | null;
50
+ /**
51
+ * Start voice recognition
52
+ */
53
+ start: () => Promise<void>;
54
+ /**
55
+ * Stop voice recognition and get final results
56
+ */
57
+ stop: () => Promise<void>;
58
+ /**
59
+ * Cancel voice recognition without getting results
60
+ */
61
+ cancel: () => Promise<void>;
62
+ /**
63
+ * Reset all state
64
+ */
65
+ reset: () => void;
66
+ }
67
+ /**
68
+ * Custom hook for voice recognition
69
+ *
70
+ * Provides a simple interface for speech-to-text functionality with automatic
71
+ * event listener setup and cleanup.
72
+ *
73
+ * @example
74
+ * ```tsx
75
+ * const { isRecording, results, start, stop } = useVoiceRecognition({
76
+ * locale: 'en-US',
77
+ * onResult: (text) => setSearchQuery(text),
78
+ * });
79
+ *
80
+ * // In your component
81
+ * <Button
82
+ * onPress={isRecording ? stop : start}
83
+ * title={isRecording ? 'Stop' : 'Start Recording'}
84
+ * />
85
+ * <Text>{results[0]}</Text>
86
+ * ```
87
+ */
88
+ export declare const useVoiceRecognition: (options?: UseVoiceRecognitionOptions) => UseVoiceRecognitionReturn;
89
+ //# sourceMappingURL=useVoiceRecognition.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useVoiceRecognition.d.ts","sourceRoot":"","sources":["../../src/hooks/useVoiceRecognition.ts"],"names":[],"mappings":"AAIA,MAAM,WAAW,0BAA0B;IACzC;;;OAGG;IACH,MAAM,CAAC,EAAE,MAAM,CAAC;IAEhB;;;OAGG;IACH,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAE/B;;;;OAIG;IACH,UAAU,CAAC,EAAE,OAAO,CAAC;IAErB;;;;OAIG;IACH,kBAAkB,CAAC,EAAE,MAAM,CAAC;IAE5B;;OAEG;IACH,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAElC;;OAEG;IACH,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACnC;AAED,MAAM,WAAW,yBAAyB;IACxC;;OAEG;IACH,WAAW,EAAE,OAAO,CAAC;IAErB;;OAEG;IACH,OAAO,EAAE,MAAM,EAAE,CAAC;IAElB;;OAEG;IACH,cAAc,EAAE,MAAM,EAAE,CAAC;IAEzB;;OAEG;IACH,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IAErB;;OAEG;IACH,KAAK,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAE3B;;OAEG;IACH,IAAI,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAE1B;;OAEG;IACH,MAAM,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAE5B;;OAEG;IACH,KAAK,EAAE,MAAM,IAAI,CAAC;CACnB;AAED;;;;;;;;;;;;;;;;;;;;GAoBG;AACH,eAAO,MAAM,mBAAmB,GAC9B,UAAS,0BAA+B,KACvC,yBAiOF,CAAC"}