@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.
- package/.env.example +22 -0
- package/.github/workflows/publish.yml +20 -0
- package/LICENSE.txt +201 -0
- package/README.md +621 -0
- package/babel.config.js +29 -0
- package/dist/adapters/__tests__/expo-router-adapter.test.d.ts +1 -0
- package/dist/adapters/expo-router-adapter.d.ts +16 -0
- package/dist/adapters/expo-router-adapter.js +521 -0
- package/dist/adapters/navigation-adapter.d.ts +20 -0
- package/dist/adapters/navigation-adapter.js +137 -0
- package/dist/audio-visualizer.d.ts +14 -0
- package/dist/audio-visualizer.js +123 -0
- package/dist/current-selection.d.ts +27 -0
- package/dist/current-selection.js +94 -0
- package/dist/errors.d.ts +19 -0
- package/dist/errors.js +37 -0
- package/dist/genie/DateTime.d.ts +66 -0
- package/dist/genie/DateTime.js +399 -0
- package/dist/genie/TimeDelta.d.ts +35 -0
- package/dist/genie/TimeDelta.js +169 -0
- package/dist/genie-view-wrapper.d.ts +1 -0
- package/dist/genie-view-wrapper.js +377 -0
- package/dist/hooks/__tests__/useSpeechRecognition.test.d.ts +1 -0
- package/dist/hooks/useSpeechRecognition.d.ts +28 -0
- package/dist/hooks/useSpeechRecognition.js +118 -0
- package/dist/index.d.ts +30 -0
- package/dist/index.js +469 -0
- package/dist/logger.d.ts +23 -0
- package/dist/logger.js +597 -0
- package/dist/logger.remote.test.d.ts +0 -0
- package/dist/modality-provider-v2.d.ts +28 -0
- package/dist/modality-provider-v2.js +1321 -0
- package/dist/modality-provider.d.ts +22 -0
- package/dist/modality-provider.js +373 -0
- package/dist/native-visibility.d.ts +28 -0
- package/dist/native-visibility.js +50 -0
- package/dist/platform/VoiceRecognitionBar.d.ts +17 -0
- package/dist/platform/VoiceRecognitionBar.js +332 -0
- package/dist/platform/components.d.ts +32 -0
- package/dist/platform/components.js +351 -0
- package/dist/platform/events.d.ts +31 -0
- package/dist/platform/events.js +274 -0
- package/dist/platform/index.d.ts +3 -0
- package/dist/platform/index.js +39 -0
- package/dist/platform/types.d.ts +79 -0
- package/dist/platform/types.js +97 -0
- package/dist/react-decorators.d.ts +87 -0
- package/dist/react-decorators.js +368 -0
- package/dist/shared-store.d.ts +74 -0
- package/dist/shared-store.js +589 -0
- package/dist/speech-recognition/__tests__/speech-recognition-groq-transport.test.d.ts +1 -0
- package/dist/speech-recognition/__tests__/speech-recognition-native.test.d.ts +1 -0
- package/dist/speech-recognition/__tests__/speech-recognition-openai-native.test.d.ts +1 -0
- package/dist/speech-recognition/__tests__/speech-recognition-openai.test.d.ts +1 -0
- package/dist/speech-recognition/__tests__/speech-recognition-unified-import.test.d.ts +0 -0
- package/dist/speech-recognition/__tests__/speech-recognition-unified.test.d.ts +1 -0
- package/dist/speech-recognition/speech-recognition-groq.d.ts +21 -0
- package/dist/speech-recognition/speech-recognition-groq.js +409 -0
- package/dist/speech-recognition/speech-recognition-mlx.d.ts +15 -0
- package/dist/speech-recognition/speech-recognition-mlx.js +393 -0
- package/dist/speech-recognition/speech-recognition-native.d.ts +24 -0
- package/dist/speech-recognition/speech-recognition-native.js +632 -0
- package/dist/speech-recognition/speech-recognition-openai-native.d.ts +40 -0
- package/dist/speech-recognition/speech-recognition-openai-native.js +653 -0
- package/dist/speech-recognition/speech-recognition-openai.d.ts +39 -0
- package/dist/speech-recognition/speech-recognition-openai.js +718 -0
- package/dist/speech-recognition/speech-recognition-unified.d.ts +93 -0
- package/dist/speech-recognition/speech-recognition-unified.js +589 -0
- package/dist/speech-recognition/utils/groq-transcription.d.ts +41 -0
- package/dist/speech-recognition/utils/groq-transcription.js +382 -0
- package/dist/speech-recognition.d.ts +7 -0
- package/dist/speech-recognition.js +61 -0
- package/dist/voice-pipeline-telemetry.d.ts +26 -0
- package/dist/voice-pipeline-telemetry.js +15 -0
- package/garrix82-reactgenie-lib-1.3.0.tgz +0 -0
- package/metro/index.js +3 -0
- package/metro/with-genie-registry.js +47 -0
- package/package.json +111 -0
- package/scripts/dry-run.js +23 -0
- package/scripts/generate-genie-registry.js +278 -0
- package/scripts/log-file-test.js +51 -0
- package/scripts/parse.js +26 -0
- package/scripts/prompt.js +19 -0
- package/scripts/set-script.js +200 -0
- package/tsconfig.json +36 -0
|
@@ -0,0 +1,351 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.TranscriptDisplay = exports.SafeContainer = exports.PlatformOverlay = exports.PlatformButton = exports.LoadingIndicator = void 0;
|
|
7
|
+
var _react = _interopRequireWildcard(require("react"));
|
|
8
|
+
var _reactNative = require("react-native");
|
|
9
|
+
var _vectorIcons = require("@expo/vector-icons");
|
|
10
|
+
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); }
|
|
11
|
+
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
12
|
+
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
|
|
13
|
+
function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
|
|
14
|
+
function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
|
|
15
|
+
function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } /**
|
|
16
|
+
* Platform-aware UI components
|
|
17
|
+
* Provides cross-platform overlay, button, and loading indicators
|
|
18
|
+
*/
|
|
19
|
+
// import { AudioVisualizer } from '../audio-visualizer';
|
|
20
|
+
|
|
21
|
+
// ============================================================================
|
|
22
|
+
// Styles
|
|
23
|
+
// ============================================================================
|
|
24
|
+
|
|
25
|
+
const styles = _reactNative.StyleSheet.create({
|
|
26
|
+
overlay: _objectSpread(_objectSpread({}, _reactNative.StyleSheet.absoluteFillObject), {}, {
|
|
27
|
+
zIndex: 3
|
|
28
|
+
}),
|
|
29
|
+
overlayPressed: _objectSpread(_objectSpread({}, _reactNative.StyleSheet.absoluteFillObject), {}, {
|
|
30
|
+
zIndex: 3
|
|
31
|
+
}),
|
|
32
|
+
loadingContainer: _objectSpread(_objectSpread({}, _reactNative.StyleSheet.absoluteFillObject), {}, {
|
|
33
|
+
justifyContent: 'center',
|
|
34
|
+
alignItems: 'center'
|
|
35
|
+
}),
|
|
36
|
+
loadingCard: _objectSpread({
|
|
37
|
+
justifyContent: 'center',
|
|
38
|
+
alignItems: 'center',
|
|
39
|
+
backgroundColor: 'rgba(255, 255, 255, 0.92)',
|
|
40
|
+
padding: 12,
|
|
41
|
+
borderRadius: 12,
|
|
42
|
+
borderWidth: 1,
|
|
43
|
+
borderColor: 'rgba(17, 24, 39, 0.08)'
|
|
44
|
+
}, _reactNative.Platform.select({
|
|
45
|
+
web: {
|
|
46
|
+
boxShadow: '0 8px 20px rgba(17, 24, 39, 0.16)'
|
|
47
|
+
},
|
|
48
|
+
default: {
|
|
49
|
+
shadowColor: '#111827',
|
|
50
|
+
shadowOffset: {
|
|
51
|
+
width: 0,
|
|
52
|
+
height: 6
|
|
53
|
+
},
|
|
54
|
+
shadowOpacity: 0.14,
|
|
55
|
+
shadowRadius: 14,
|
|
56
|
+
elevation: 6
|
|
57
|
+
}
|
|
58
|
+
})),
|
|
59
|
+
loadingMessage: {
|
|
60
|
+
marginTop: 8,
|
|
61
|
+
color: '#1F2937',
|
|
62
|
+
fontSize: 14,
|
|
63
|
+
textAlign: 'center'
|
|
64
|
+
},
|
|
65
|
+
transcriptContainer: _objectSpread({
|
|
66
|
+
position: 'absolute',
|
|
67
|
+
bottom: '10%',
|
|
68
|
+
left: '50%',
|
|
69
|
+
transform: [{
|
|
70
|
+
translateX: -50
|
|
71
|
+
}],
|
|
72
|
+
backgroundColor: '#ffffff',
|
|
73
|
+
padding: 10,
|
|
74
|
+
borderRadius: 10,
|
|
75
|
+
maxWidth: '80%'
|
|
76
|
+
}, _reactNative.Platform.select({
|
|
77
|
+
web: {
|
|
78
|
+
boxShadow: '0 0 10px rgba(0, 0, 0, 0.3)'
|
|
79
|
+
},
|
|
80
|
+
default: {
|
|
81
|
+
shadowColor: '#000000',
|
|
82
|
+
shadowOffset: {
|
|
83
|
+
width: 0,
|
|
84
|
+
height: 2
|
|
85
|
+
},
|
|
86
|
+
shadowOpacity: 0.3,
|
|
87
|
+
shadowRadius: 10,
|
|
88
|
+
elevation: 5
|
|
89
|
+
}
|
|
90
|
+
})),
|
|
91
|
+
transcriptText: {
|
|
92
|
+
fontSize: 20,
|
|
93
|
+
textAlign: 'center',
|
|
94
|
+
color: '#000000'
|
|
95
|
+
},
|
|
96
|
+
floatingButton: {
|
|
97
|
+
position: 'absolute',
|
|
98
|
+
bottom: 50,
|
|
99
|
+
right: 10,
|
|
100
|
+
zIndex: 4
|
|
101
|
+
},
|
|
102
|
+
buttonCircle: _objectSpread({
|
|
103
|
+
borderRadius: 25,
|
|
104
|
+
justifyContent: 'center',
|
|
105
|
+
alignItems: 'center'
|
|
106
|
+
}, _reactNative.Platform.select({
|
|
107
|
+
web: {
|
|
108
|
+
boxShadow: '0 2px 8px rgba(0, 0, 0, 0.2)'
|
|
109
|
+
},
|
|
110
|
+
default: {
|
|
111
|
+
shadowColor: '#000000',
|
|
112
|
+
shadowOffset: {
|
|
113
|
+
width: 0,
|
|
114
|
+
height: 2
|
|
115
|
+
},
|
|
116
|
+
shadowOpacity: 0.2,
|
|
117
|
+
shadowRadius: 4,
|
|
118
|
+
elevation: 3
|
|
119
|
+
}
|
|
120
|
+
}))
|
|
121
|
+
});
|
|
122
|
+
const ROTATION_DURATION_MS = 900;
|
|
123
|
+
const DEFAULT_LOADER_COLOR = '#4B5563';
|
|
124
|
+
const DEFAULT_LOADER_SIZE = 28;
|
|
125
|
+
const RotatingLoader = ({
|
|
126
|
+
color = DEFAULT_LOADER_COLOR,
|
|
127
|
+
message
|
|
128
|
+
}) => {
|
|
129
|
+
const spinValue = (0, _react.useRef)(new _reactNative.Animated.Value(0)).current;
|
|
130
|
+
(0, _react.useEffect)(() => {
|
|
131
|
+
spinValue.setValue(0);
|
|
132
|
+
const animation = _reactNative.Animated.loop(_reactNative.Animated.timing(spinValue, {
|
|
133
|
+
toValue: 1,
|
|
134
|
+
duration: ROTATION_DURATION_MS,
|
|
135
|
+
easing: _reactNative.Easing.linear,
|
|
136
|
+
useNativeDriver: true
|
|
137
|
+
}));
|
|
138
|
+
animation.start();
|
|
139
|
+
return () => {
|
|
140
|
+
animation.stop();
|
|
141
|
+
};
|
|
142
|
+
}, [spinValue]);
|
|
143
|
+
const spin = spinValue.interpolate({
|
|
144
|
+
inputRange: [0, 1],
|
|
145
|
+
outputRange: ['0deg', '360deg']
|
|
146
|
+
});
|
|
147
|
+
return /*#__PURE__*/_react.default.createElement(_reactNative.View, {
|
|
148
|
+
style: styles.loadingContainer,
|
|
149
|
+
pointerEvents: "none",
|
|
150
|
+
testID: "platform-loader"
|
|
151
|
+
}, /*#__PURE__*/_react.default.createElement(_reactNative.View, {
|
|
152
|
+
style: styles.loadingCard
|
|
153
|
+
}, /*#__PURE__*/_react.default.createElement(_reactNative.Animated.View, {
|
|
154
|
+
style: {
|
|
155
|
+
transform: [{
|
|
156
|
+
rotate: spin
|
|
157
|
+
}]
|
|
158
|
+
}
|
|
159
|
+
}, /*#__PURE__*/_react.default.createElement(_vectorIcons.Ionicons, {
|
|
160
|
+
name: "sync",
|
|
161
|
+
size: DEFAULT_LOADER_SIZE,
|
|
162
|
+
color: color,
|
|
163
|
+
testID: "platform-loader-icon"
|
|
164
|
+
})), message ? /*#__PURE__*/_react.default.createElement(_reactNative.Text, {
|
|
165
|
+
style: styles.loadingMessage
|
|
166
|
+
}, message) : null));
|
|
167
|
+
};
|
|
168
|
+
|
|
169
|
+
// ============================================================================
|
|
170
|
+
// Platform Overlay Component
|
|
171
|
+
// ============================================================================
|
|
172
|
+
|
|
173
|
+
/**
|
|
174
|
+
* Platform-aware overlay component
|
|
175
|
+
* Handles clicks/touches and provides visual feedback
|
|
176
|
+
*/
|
|
177
|
+
const PlatformOverlay = ({
|
|
178
|
+
visible,
|
|
179
|
+
onPress,
|
|
180
|
+
onPressDown,
|
|
181
|
+
interactive = true,
|
|
182
|
+
backgroundColor = 'rgba(204, 204, 204, 0.5)',
|
|
183
|
+
opacity = 1,
|
|
184
|
+
isProcessing = false,
|
|
185
|
+
isListening = false,
|
|
186
|
+
audioLevel = 0,
|
|
187
|
+
transcriptText = '',
|
|
188
|
+
showTranscript = false,
|
|
189
|
+
showAudioVisualizer = true,
|
|
190
|
+
children
|
|
191
|
+
}) => {
|
|
192
|
+
const [isPressed, setIsPressed] = _react.default.useState(false);
|
|
193
|
+
const overlayStyle = (0, _react.useMemo)(() => _objectSpread(_objectSpread({}, isPressed ? styles.overlayPressed : styles.overlay), {}, {
|
|
194
|
+
backgroundColor: isPressed ? 'rgba(127, 127, 127, 0.5)' : backgroundColor,
|
|
195
|
+
opacity,
|
|
196
|
+
display: visible ? 'flex' : 'none'
|
|
197
|
+
}), [visible, isPressed, backgroundColor, opacity]);
|
|
198
|
+
if (!visible) {
|
|
199
|
+
return null;
|
|
200
|
+
}
|
|
201
|
+
const handlePressIn = event => {
|
|
202
|
+
if (_reactNative.Platform.OS === 'web') {
|
|
203
|
+
event?.preventDefault?.();
|
|
204
|
+
event?.stopPropagation?.();
|
|
205
|
+
}
|
|
206
|
+
setIsPressed(true);
|
|
207
|
+
if (onPressDown) {
|
|
208
|
+
onPressDown(event);
|
|
209
|
+
}
|
|
210
|
+
};
|
|
211
|
+
const handlePress = event => {
|
|
212
|
+
if (_reactNative.Platform.OS === 'web') {
|
|
213
|
+
event?.preventDefault?.();
|
|
214
|
+
event?.stopPropagation?.();
|
|
215
|
+
}
|
|
216
|
+
setIsPressed(false);
|
|
217
|
+
onPress(event);
|
|
218
|
+
};
|
|
219
|
+
const handlePressCancel = event => {
|
|
220
|
+
if (_reactNative.Platform.OS === 'web') {
|
|
221
|
+
event?.preventDefault?.();
|
|
222
|
+
event?.stopPropagation?.();
|
|
223
|
+
}
|
|
224
|
+
setIsPressed(false);
|
|
225
|
+
};
|
|
226
|
+
const overlayContent = /*#__PURE__*/_react.default.createElement(_react.default.Fragment, null, isProcessing && /*#__PURE__*/_react.default.createElement(RotatingLoader, null), showTranscript && transcriptText && /*#__PURE__*/_react.default.createElement(_reactNative.View, {
|
|
227
|
+
style: styles.transcriptContainer
|
|
228
|
+
}, /*#__PURE__*/_react.default.createElement(_reactNative.Text, {
|
|
229
|
+
style: styles.transcriptText
|
|
230
|
+
}, transcriptText)), children);
|
|
231
|
+
if (_reactNative.Platform.OS === "web") {
|
|
232
|
+
const webPointerEvents = interactive ? "auto" : "none";
|
|
233
|
+
return /*#__PURE__*/_react.default.createElement(_reactNative.View, {
|
|
234
|
+
style: overlayStyle,
|
|
235
|
+
pointerEvents: webPointerEvents,
|
|
236
|
+
testID: "platform-overlay-interactive-web",
|
|
237
|
+
onPointerDown: interactive ? handlePressIn : undefined,
|
|
238
|
+
onPointerUp: interactive ? handlePress : undefined,
|
|
239
|
+
onPointerCancel: interactive ? handlePressCancel : undefined
|
|
240
|
+
}, overlayContent);
|
|
241
|
+
}
|
|
242
|
+
return /*#__PURE__*/_react.default.createElement(_reactNative.TouchableOpacity, {
|
|
243
|
+
style: overlayStyle,
|
|
244
|
+
activeOpacity: 1,
|
|
245
|
+
onPressIn: interactive ? handlePressIn : undefined,
|
|
246
|
+
onPress: interactive ? handlePress : undefined,
|
|
247
|
+
disabled: !interactive,
|
|
248
|
+
testID: "platform-overlay-interactive-native"
|
|
249
|
+
}, overlayContent);
|
|
250
|
+
};
|
|
251
|
+
|
|
252
|
+
// ============================================================================
|
|
253
|
+
// Platform Button Component
|
|
254
|
+
// ============================================================================
|
|
255
|
+
|
|
256
|
+
/**
|
|
257
|
+
* Platform-aware floating button
|
|
258
|
+
* Typically used for voice recognition trigger
|
|
259
|
+
*/
|
|
260
|
+
exports.PlatformOverlay = PlatformOverlay;
|
|
261
|
+
const PlatformButton = ({
|
|
262
|
+
onPress,
|
|
263
|
+
backgroundColor = '#cccccc',
|
|
264
|
+
size = 50,
|
|
265
|
+
style,
|
|
266
|
+
disabled = false,
|
|
267
|
+
children
|
|
268
|
+
}) => {
|
|
269
|
+
const buttonStyle = (0, _react.useMemo)(() => _objectSpread(_objectSpread({}, styles.buttonCircle), {}, {
|
|
270
|
+
width: size,
|
|
271
|
+
height: size,
|
|
272
|
+
borderRadius: size / 2,
|
|
273
|
+
backgroundColor,
|
|
274
|
+
opacity: disabled ? 0.5 : 1
|
|
275
|
+
}), [size, backgroundColor, disabled]);
|
|
276
|
+
return /*#__PURE__*/_react.default.createElement(_reactNative.TouchableOpacity, {
|
|
277
|
+
onPress: onPress,
|
|
278
|
+
disabled: disabled,
|
|
279
|
+
style: [styles.floatingButton, style]
|
|
280
|
+
}, /*#__PURE__*/_react.default.createElement(_reactNative.View, {
|
|
281
|
+
style: buttonStyle
|
|
282
|
+
}, children));
|
|
283
|
+
};
|
|
284
|
+
|
|
285
|
+
// ============================================================================
|
|
286
|
+
// Loading Indicator Component
|
|
287
|
+
// ============================================================================
|
|
288
|
+
exports.PlatformButton = PlatformButton;
|
|
289
|
+
/**
|
|
290
|
+
* Platform-aware loading indicator
|
|
291
|
+
*/
|
|
292
|
+
const LoadingIndicator = ({
|
|
293
|
+
visible,
|
|
294
|
+
size: _size = 'large',
|
|
295
|
+
color = '#888888',
|
|
296
|
+
message
|
|
297
|
+
}) => {
|
|
298
|
+
void _size;
|
|
299
|
+
if (!visible) {
|
|
300
|
+
return null;
|
|
301
|
+
}
|
|
302
|
+
return /*#__PURE__*/_react.default.createElement(RotatingLoader, {
|
|
303
|
+
color: color,
|
|
304
|
+
message: message
|
|
305
|
+
});
|
|
306
|
+
};
|
|
307
|
+
|
|
308
|
+
// ============================================================================
|
|
309
|
+
// Transcript Display Component
|
|
310
|
+
// ============================================================================
|
|
311
|
+
exports.LoadingIndicator = LoadingIndicator;
|
|
312
|
+
/**
|
|
313
|
+
* Platform-aware transcript display
|
|
314
|
+
* Shows voice recognition results
|
|
315
|
+
*/
|
|
316
|
+
const TranscriptDisplay = ({
|
|
317
|
+
visible,
|
|
318
|
+
text,
|
|
319
|
+
style,
|
|
320
|
+
textStyle
|
|
321
|
+
}) => {
|
|
322
|
+
if (!visible || !text) {
|
|
323
|
+
return null;
|
|
324
|
+
}
|
|
325
|
+
return /*#__PURE__*/_react.default.createElement(_reactNative.View, {
|
|
326
|
+
style: [styles.transcriptContainer, style]
|
|
327
|
+
}, /*#__PURE__*/_react.default.createElement(_reactNative.Text, {
|
|
328
|
+
style: [styles.transcriptText, textStyle]
|
|
329
|
+
}, text));
|
|
330
|
+
};
|
|
331
|
+
|
|
332
|
+
// ============================================================================
|
|
333
|
+
// Helper Components
|
|
334
|
+
// ============================================================================
|
|
335
|
+
|
|
336
|
+
/**
|
|
337
|
+
* Platform-aware container with safe area handling
|
|
338
|
+
*/
|
|
339
|
+
exports.TranscriptDisplay = TranscriptDisplay;
|
|
340
|
+
const SafeContainer = ({
|
|
341
|
+
children,
|
|
342
|
+
style
|
|
343
|
+
}) => {
|
|
344
|
+
return /*#__PURE__*/_react.default.createElement(_reactNative.View, {
|
|
345
|
+
style: [{
|
|
346
|
+
flex: 1
|
|
347
|
+
}, style]
|
|
348
|
+
}, children);
|
|
349
|
+
};
|
|
350
|
+
exports.SafeContainer = SafeContainer;
|
|
351
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","_reactNative","_vectorIcons","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","ownKeys","keys","getOwnPropertySymbols","filter","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","_toPropertyKey","value","configurable","writable","_toPrimitive","Symbol","toPrimitive","TypeError","String","Number","styles","StyleSheet","create","overlay","absoluteFillObject","zIndex","overlayPressed","loadingContainer","justifyContent","alignItems","loadingCard","backgroundColor","padding","borderRadius","borderWidth","borderColor","Platform","select","web","boxShadow","shadowColor","shadowOffset","width","height","shadowOpacity","shadowRadius","elevation","loadingMessage","marginTop","color","fontSize","textAlign","transcriptContainer","position","bottom","left","transform","translateX","maxWidth","transcriptText","floatingButton","right","buttonCircle","ROTATION_DURATION_MS","DEFAULT_LOADER_COLOR","DEFAULT_LOADER_SIZE","RotatingLoader","message","spinValue","useRef","Animated","Value","current","useEffect","setValue","animation","loop","timing","toValue","duration","easing","Easing","linear","useNativeDriver","start","stop","spin","interpolate","inputRange","outputRange","createElement","View","style","pointerEvents","testID","rotate","Ionicons","name","size","Text","PlatformOverlay","visible","onPress","onPressDown","interactive","opacity","isProcessing","isListening","audioLevel","showTranscript","showAudioVisualizer","children","isPressed","setIsPressed","React","useState","overlayStyle","useMemo","display","handlePressIn","event","OS","preventDefault","stopPropagation","handlePress","handlePressCancel","overlayContent","Fragment","webPointerEvents","onPointerDown","undefined","onPointerUp","onPointerCancel","TouchableOpacity","activeOpacity","onPressIn","disabled","exports","PlatformButton","buttonStyle","LoadingIndicator","_size","TranscriptDisplay","text","textStyle","SafeContainer","flex"],"sources":["../../src/platform/components.tsx"],"sourcesContent":["/**\n * Platform-aware UI components\n * Provides cross-platform overlay, button, and loading indicators\n */\n\nimport React, { useEffect, useMemo, useRef } from 'react';\nimport {\n  View,\n  Text,\n  TouchableOpacity,\n  Animated,\n  Easing,\n  StyleSheet,\n  Platform,\n  ViewStyle,\n  TextStyle,\n} from 'react-native';\nimport { Ionicons } from '@expo/vector-icons';\nimport {\n  PlatformOverlayProps,\n  PlatformButtonProps,\n  PlatformPressEvent,\n} from './types';\nimport { getCoordinates } from './events';\n// import { AudioVisualizer } from '../audio-visualizer';\n\n// ============================================================================\n// Styles\n// ============================================================================\n\nconst styles = StyleSheet.create({\n  overlay: {\n    ...StyleSheet.absoluteFillObject,\n    zIndex: 3,\n  },\n  overlayPressed: {\n    ...StyleSheet.absoluteFillObject,\n    zIndex: 3,\n  },\n  loadingContainer: {\n    ...StyleSheet.absoluteFillObject,\n    justifyContent: 'center',\n    alignItems: 'center',\n  },\n  loadingCard: {\n    justifyContent: 'center',\n    alignItems: 'center',\n    backgroundColor: 'rgba(255, 255, 255, 0.92)',\n    padding: 12,\n    borderRadius: 12,\n    borderWidth: 1,\n    borderColor: 'rgba(17, 24, 39, 0.08)',\n    ...Platform.select({\n      web: {\n        boxShadow: '0 8px 20px rgba(17, 24, 39, 0.16)',\n      },\n      default: {\n        shadowColor: '#111827',\n        shadowOffset: { width: 0, height: 6 },\n        shadowOpacity: 0.14,\n        shadowRadius: 14,\n        elevation: 6,\n      },\n    }),\n  },\n  loadingMessage: {\n    marginTop: 8,\n    color: '#1F2937',\n    fontSize: 14,\n    textAlign: 'center',\n  },\n  transcriptContainer: {\n    position: 'absolute',\n    bottom: '10%',\n    left: '50%',\n    transform: [{ translateX: -50 }],\n    backgroundColor: '#ffffff',\n    padding: 10,\n    borderRadius: 10,\n    maxWidth: '80%',\n    ...Platform.select({\n      web: {\n        boxShadow: '0 0 10px rgba(0, 0, 0, 0.3)',\n      },\n      default: {\n        shadowColor: '#000000',\n        shadowOffset: { width: 0, height: 2 },\n        shadowOpacity: 0.3,\n        shadowRadius: 10,\n        elevation: 5,\n      },\n    }),\n  },\n  transcriptText: {\n    fontSize: 20,\n    textAlign: 'center',\n    color: '#000000',\n  },\n  floatingButton: {\n    position: 'absolute',\n    bottom: 50,\n    right: 10,\n    zIndex: 4,\n  },\n  buttonCircle: {\n    borderRadius: 25,\n    justifyContent: 'center',\n    alignItems: 'center',\n    ...Platform.select({\n      web: {\n        boxShadow: '0 2px 8px rgba(0, 0, 0, 0.2)',\n      },\n      default: {\n        shadowColor: '#000000',\n        shadowOffset: { width: 0, height: 2 },\n        shadowOpacity: 0.2,\n        shadowRadius: 4,\n        elevation: 3,\n      },\n    }),\n  },\n});\n\nconst ROTATION_DURATION_MS = 900;\nconst DEFAULT_LOADER_COLOR = '#4B5563';\nconst DEFAULT_LOADER_SIZE = 28;\n\ninterface RotatingLoaderProps {\n  color?: string;\n  message?: string;\n}\n\nconst RotatingLoader: React.FC<RotatingLoaderProps> = ({\n  color = DEFAULT_LOADER_COLOR,\n  message,\n}) => {\n  const spinValue = useRef(new Animated.Value(0)).current;\n\n  useEffect(() => {\n    spinValue.setValue(0);\n    const animation = Animated.loop(\n      Animated.timing(spinValue, {\n        toValue: 1,\n        duration: ROTATION_DURATION_MS,\n        easing: Easing.linear,\n        useNativeDriver: true,\n      })\n    );\n\n    animation.start();\n    return () => {\n      animation.stop();\n    };\n  }, [spinValue]);\n\n  const spin = spinValue.interpolate({\n    inputRange: [0, 1],\n    outputRange: ['0deg', '360deg'],\n  });\n\n  return (\n    <View style={styles.loadingContainer} pointerEvents=\"none\" testID=\"platform-loader\">\n      <View style={styles.loadingCard}>\n        <Animated.View style={{ transform: [{ rotate: spin }] }}>\n          <Ionicons\n            name=\"sync\"\n            size={DEFAULT_LOADER_SIZE}\n            color={color}\n            testID=\"platform-loader-icon\"\n          />\n        </Animated.View>\n        {message ? <Text style={styles.loadingMessage}>{message}</Text> : null}\n      </View>\n    </View>\n  );\n};\n\n// ============================================================================\n// Platform Overlay Component\n// ============================================================================\n\ninterface OverlayContentProps {\n  isProcessing?: boolean;\n  isListening?: boolean;\n  audioLevel?: number;\n  transcriptText?: string;\n  showTranscript?: boolean;\n  showAudioVisualizer?: boolean;\n}\n\n/**\n * Platform-aware overlay component\n * Handles clicks/touches and provides visual feedback\n */\nexport const PlatformOverlay: React.FC<PlatformOverlayProps & OverlayContentProps> = ({\n  visible,\n  onPress,\n  onPressDown,\n  interactive = true,\n  backgroundColor = 'rgba(204, 204, 204, 0.5)',\n  opacity = 1,\n  isProcessing = false,\n  isListening = false,\n  audioLevel = 0,\n  transcriptText = '',\n  showTranscript = false,\n  showAudioVisualizer = true,\n  children,\n}) => {\n  const [isPressed, setIsPressed] = React.useState(false);\n  const overlayStyle = useMemo<ViewStyle>(\n    () => ({\n      ...(isPressed ? styles.overlayPressed : styles.overlay),\n      backgroundColor: isPressed ? 'rgba(127, 127, 127, 0.5)' : backgroundColor,\n      opacity,\n      display: visible ? 'flex' : 'none',\n    }),\n    [visible, isPressed, backgroundColor, opacity]\n  );\n\n  if (!visible) {\n    return null;\n  }\n\n  const handlePressIn = (event: any) => {\n    if (Platform.OS === 'web') {\n      event?.preventDefault?.();\n      event?.stopPropagation?.();\n    }\n    setIsPressed(true);\n    if (onPressDown) {\n      onPressDown(event as PlatformPressEvent);\n    }\n  };\n\n  const handlePress = (event: any) => {\n    if (Platform.OS === 'web') {\n      event?.preventDefault?.();\n      event?.stopPropagation?.();\n    }\n    setIsPressed(false);\n    onPress(event as PlatformPressEvent);\n  };\n\n  const handlePressCancel = (event: any) => {\n    if (Platform.OS === 'web') {\n      event?.preventDefault?.();\n      event?.stopPropagation?.();\n    }\n    setIsPressed(false);\n  };\n\n  const overlayContent = (\n    <>\n      {isProcessing && (\n        <RotatingLoader />\n      )}\n\n      {/* Show audio visualizer when listening instead of transcript */}\n      {/* {isListening && showAudioVisualizer && (\n        <View style={styles.transcriptContainer}>\n          <AudioVisualizer audioLevel={audioLevel} barCount={7} barColor=\"#0000ff\" />\n        </View>\n      )} */}\n\n      {/* Show transcript text when processing or listening */}\n      {showTranscript && transcriptText && (\n        <View style={styles.transcriptContainer}>\n          <Text style={styles.transcriptText}>\n            {transcriptText}\n          </Text>\n        </View>\n      )}\n\n      {children}\n    </>\n  );\n\n  if (Platform.OS === \"web\") {\n    const webPointerEvents = interactive ? \"auto\" : \"none\";\n    return (\n      <View\n        style={overlayStyle}\n        pointerEvents={webPointerEvents}\n        testID=\"platform-overlay-interactive-web\"\n        onPointerDown={interactive ? handlePressIn : undefined}\n        onPointerUp={interactive ? handlePress : undefined}\n        onPointerCancel={interactive ? handlePressCancel : undefined}\n      >\n        {overlayContent}\n      </View>\n    );\n  }\n\n  return (\n    <TouchableOpacity\n      style={overlayStyle}\n      activeOpacity={1}\n      onPressIn={interactive ? handlePressIn : undefined}\n      onPress={interactive ? handlePress : undefined}\n      disabled={!interactive}\n      testID=\"platform-overlay-interactive-native\"\n    >\n      {overlayContent}\n    </TouchableOpacity>\n  );\n};\n\n// ============================================================================\n// Platform Button Component\n// ============================================================================\n\n/**\n * Platform-aware floating button\n * Typically used for voice recognition trigger\n */\nexport const PlatformButton: React.FC<PlatformButtonProps> = ({\n  onPress,\n  backgroundColor = '#cccccc',\n  size = 50,\n  style,\n  disabled = false,\n  children,\n}) => {\n  const buttonStyle = useMemo<ViewStyle>(\n    () => ({\n      ...styles.buttonCircle,\n      width: size,\n      height: size,\n      borderRadius: size / 2,\n      backgroundColor,\n      opacity: disabled ? 0.5 : 1,\n    }),\n    [size, backgroundColor, disabled]\n  );\n\n  return (\n    <TouchableOpacity\n      onPress={onPress}\n      disabled={disabled}\n      style={[styles.floatingButton, style]}\n    >\n      <View style={buttonStyle}>{children}</View>\n    </TouchableOpacity>\n  );\n};\n\n// ============================================================================\n// Loading Indicator Component\n// ============================================================================\n\ninterface LoadingIndicatorProps {\n  visible: boolean;\n  size?: 'small' | 'large';\n  color?: string;\n  message?: string;\n}\n\n/**\n * Platform-aware loading indicator\n */\nexport const LoadingIndicator: React.FC<LoadingIndicatorProps> = ({\n  visible,\n  size: _size = 'large',\n  color = '#888888',\n  message,\n}) => {\n  void _size;\n\n  if (!visible) {\n    return null;\n  }\n\n  return (\n    <RotatingLoader color={color} message={message} />\n  );\n};\n\n// ============================================================================\n// Transcript Display Component\n// ============================================================================\n\ninterface TranscriptDisplayProps {\n  visible: boolean;\n  text: string;\n  style?: ViewStyle;\n  textStyle?: TextStyle;\n}\n\n/**\n * Platform-aware transcript display\n * Shows voice recognition results\n */\nexport const TranscriptDisplay: React.FC<TranscriptDisplayProps> = ({\n  visible,\n  text,\n  style,\n  textStyle,\n}) => {\n  if (!visible || !text) {\n    return null;\n  }\n\n  return (\n    <View style={[styles.transcriptContainer, style]}>\n      <Text style={[styles.transcriptText, textStyle]}>{text}</Text>\n    </View>\n  );\n};\n\n// ============================================================================\n// Helper Components\n// ============================================================================\n\n/**\n * Platform-aware container with safe area handling\n */\nexport const SafeContainer: React.FC<{\n  children: React.ReactNode;\n  style?: ViewStyle;\n}> = ({ children, style }) => {\n  return (\n    <View style={[{ flex: 1 }, style]}>\n      {children}\n    </View>\n  );\n};\n"],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { PlatformPressEvent, Coordinates, PlatformCapabilities } from './types';
|
|
2
|
+
export declare function getCoordinates(event: PlatformPressEvent): Coordinates;
|
|
3
|
+
export declare function getAbsoluteCoordinates(event: PlatformPressEvent): Coordinates;
|
|
4
|
+
export declare function preventDefault(event: PlatformPressEvent): void;
|
|
5
|
+
export declare function stopPropagation(event: PlatformPressEvent): void;
|
|
6
|
+
export declare function getPlatformCapabilities(): PlatformCapabilities;
|
|
7
|
+
export declare function isWebPlatform(): boolean;
|
|
8
|
+
export declare function isIOSPlatform(): boolean;
|
|
9
|
+
export declare function isAndroidPlatform(): boolean;
|
|
10
|
+
export declare function isNativePlatform(): boolean;
|
|
11
|
+
export declare function createPressHandler(handler: (coords: Coordinates, event: PlatformPressEvent) => void): (event: PlatformPressEvent) => void;
|
|
12
|
+
export declare function createDebouncedPressHandler(handler: (coords: Coordinates, event: PlatformPressEvent) => void, delay?: number): (event: PlatformPressEvent) => void;
|
|
13
|
+
export declare function getDistance(coord1: Coordinates, coord2: Coordinates): number;
|
|
14
|
+
export declare function isCoordinateInRect(coord: Coordinates, rect: {
|
|
15
|
+
x: number;
|
|
16
|
+
y: number;
|
|
17
|
+
width: number;
|
|
18
|
+
height: number;
|
|
19
|
+
}): boolean;
|
|
20
|
+
export declare function getClosestPointOnRect(coord: Coordinates, rect: {
|
|
21
|
+
x: number;
|
|
22
|
+
y: number;
|
|
23
|
+
width: number;
|
|
24
|
+
height: number;
|
|
25
|
+
}): Coordinates;
|
|
26
|
+
export declare function getDistanceToRectSquared(coord: Coordinates, rect: {
|
|
27
|
+
x: number;
|
|
28
|
+
y: number;
|
|
29
|
+
width: number;
|
|
30
|
+
height: number;
|
|
31
|
+
}): number;
|