@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,137 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.createScreenWrapper = createScreenWrapper;
7
+ exports.isExpoRouter = isExpoRouter;
8
+ exports.useNavigationAdapter = useNavigationAdapter;
9
+ exports.useRouteParams = useRouteParams;
10
+ exports.withNavigationAdapter = withNavigationAdapter;
11
+ var _react = _interopRequireWildcard(require("react"));
12
+ 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); }
13
+ function _extends() { return _extends = Object.assign ? Object.assign.bind() : function (n) { for (var e = 1; e < arguments.length; e++) { var t = arguments[e]; for (var r in t) ({}).hasOwnProperty.call(t, r) && (n[r] = t[r]); } return n; }, _extends.apply(null, arguments); } /**
14
+ * Navigation Adapter for expo-router and @react-navigation/native
15
+ * Provides a unified navigation interface that works with both paradigms
16
+ */
17
+ // Type definitions for navigation adapters
18
+
19
+ // Detect if expo-router is available
20
+ let expoRouter = null;
21
+ let expoRouterHooks = null;
22
+ try {
23
+ expoRouter = require('expo-router');
24
+ expoRouterHooks = {
25
+ useRouter: expoRouter.useRouter,
26
+ useLocalSearchParams: expoRouter.useLocalSearchParams,
27
+ usePathname: expoRouter.usePathname,
28
+ useNavigation: expoRouter.useNavigation
29
+ };
30
+ } catch (e) {
31
+ // expo-router not available, will use @react-navigation/native
32
+ }
33
+
34
+ /**
35
+ * Hook to get unified navigation adapter
36
+ * Works with both expo-router and @react-navigation/native
37
+ */
38
+ function useNavigationAdapter() {
39
+ if (expoRouterHooks) {
40
+ // Use expo-router
41
+ const router = expoRouterHooks.useRouter();
42
+ const navigation = expoRouterHooks.useNavigation();
43
+ return {
44
+ push: (routeName, params) => {
45
+ // Convert route name to expo-router path
46
+ const path = routeName.toLowerCase().replace(/\s+/g, '-');
47
+ router.push({
48
+ pathname: `/${path}`,
49
+ params: params || {}
50
+ });
51
+ },
52
+ navigate: (routeName, params) => {
53
+ const path = routeName.toLowerCase().replace(/\s+/g, '-');
54
+ router.navigate({
55
+ pathname: `/${path}`,
56
+ params: params || {}
57
+ });
58
+ },
59
+ goBack: () => {
60
+ if (router.canGoBack()) {
61
+ router.back();
62
+ }
63
+ },
64
+ canGoBack: () => router.canGoBack(),
65
+ setOptions: options => {
66
+ if (navigation && navigation.setOptions) {
67
+ navigation.setOptions(options);
68
+ }
69
+ },
70
+ getState: () => navigation?.getState?.() || null
71
+ };
72
+ } else {
73
+ // Fallback: will be injected by NavigationContainer
74
+ throw new Error('Navigation adapter must be used within NavigationContainer or expo-router context');
75
+ }
76
+ }
77
+
78
+ /**
79
+ * HOC to inject navigation adapter into components
80
+ * Provides backward compatibility with class components
81
+ */
82
+ function withNavigationAdapter(Component) {
83
+ return props => {
84
+ const navigation = useNavigationAdapter();
85
+ return /*#__PURE__*/_react.default.createElement(Component, _extends({}, props, {
86
+ navigation: navigation
87
+ }));
88
+ };
89
+ }
90
+
91
+ /**
92
+ * Hook to get route params (works with both navigation systems)
93
+ */
94
+ function useRouteParams() {
95
+ if (expoRouterHooks) {
96
+ return expoRouterHooks.useLocalSearchParams();
97
+ }
98
+ // Will be provided by NavigationContainer route prop
99
+ return {};
100
+ }
101
+
102
+ /**
103
+ * Compatibility wrapper for screens
104
+ * Normalizes props between expo-router and react-navigation
105
+ */
106
+ function createScreenWrapper(Screen, options) {
107
+ return function WrappedScreen(props) {
108
+ const params = useRouteParams();
109
+ const navigation = props.navigation || useNavigationAdapter();
110
+ (0, _react.useEffect)(() => {
111
+ if (options && navigation.setOptions) {
112
+ const screenOptions = {
113
+ headerShown: options.headerShown !== false
114
+ };
115
+ if (options.title) {
116
+ screenOptions.title = options.title(params);
117
+ }
118
+ navigation.setOptions(screenOptions);
119
+ }
120
+ }, [navigation, params]);
121
+ return /*#__PURE__*/_react.default.createElement(Screen, _extends({}, props, params, {
122
+ navigation: navigation
123
+ }));
124
+ };
125
+ }
126
+
127
+ /**
128
+ * Check if running in expo-router environment
129
+ */
130
+ function isExpoRouter() {
131
+ return expoRouter !== null;
132
+ }
133
+
134
+ /**
135
+ * Export for type checking
136
+ */
137
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireWildcard","require","e","t","WeakMap","r","n","__esModule","o","i","f","__proto__","default","has","get","set","hasOwnProperty","call","Object","defineProperty","getOwnPropertyDescriptor","_extends","assign","bind","arguments","length","apply","expoRouter","expoRouterHooks","useRouter","useLocalSearchParams","usePathname","useNavigation","useNavigationAdapter","router","navigation","push","routeName","params","path","toLowerCase","replace","pathname","navigate","goBack","canGoBack","back","setOptions","options","getState","Error","withNavigationAdapter","Component","props","createElement","useRouteParams","createScreenWrapper","Screen","WrappedScreen","useEffect","screenOptions","headerShown","title","isExpoRouter"],"sources":["../../src/adapters/navigation-adapter.tsx"],"sourcesContent":["/**\n * Navigation Adapter for expo-router and @react-navigation/native\n * Provides a unified navigation interface that works with both paradigms\n */\n\nimport React, { useEffect } from 'react';\n\n// Type definitions for navigation adapters\nexport interface NavigationAdapter {\n  push: (routeName: string, params?: any) => void;\n  navigate: (routeName: string, params?: any) => void;\n  goBack: () => void;\n  canGoBack: () => boolean;\n  setOptions: (options: any) => void;\n  getState: () => any;\n}\n\n// Detect if expo-router is available\nlet expoRouter: any = null;\nlet expoRouterHooks: any = null;\ntry {\n  expoRouter = require('expo-router');\n  expoRouterHooks = {\n    useRouter: expoRouter.useRouter,\n    useLocalSearchParams: expoRouter.useLocalSearchParams,\n    usePathname: expoRouter.usePathname,\n    useNavigation: expoRouter.useNavigation,\n  };\n} catch (e) {\n  // expo-router not available, will use @react-navigation/native\n}\n\n/**\n * Hook to get unified navigation adapter\n * Works with both expo-router and @react-navigation/native\n */\nexport function useNavigationAdapter(): NavigationAdapter {\n  if (expoRouterHooks) {\n    // Use expo-router\n    const router = expoRouterHooks.useRouter();\n    const navigation = expoRouterHooks.useNavigation();\n    \n    return {\n      push: (routeName: string, params?: any) => {\n        // Convert route name to expo-router path\n        const path = routeName.toLowerCase().replace(/\\s+/g, '-');\n        router.push({\n          pathname: `/${path}`,\n          params: params || {},\n        });\n      },\n      navigate: (routeName: string, params?: any) => {\n        const path = routeName.toLowerCase().replace(/\\s+/g, '-');\n        router.navigate({\n          pathname: `/${path}`,\n          params: params || {},\n        });\n      },\n      goBack: () => {\n        if (router.canGoBack()) {\n          router.back();\n        }\n      },\n      canGoBack: () => router.canGoBack(),\n      setOptions: (options: any) => {\n        if (navigation && navigation.setOptions) {\n          navigation.setOptions(options);\n        }\n      },\n      getState: () => navigation?.getState?.() || null,\n    };\n  } else {\n    // Fallback: will be injected by NavigationContainer\n    throw new Error('Navigation adapter must be used within NavigationContainer or expo-router context');\n  }\n}\n\n/**\n * HOC to inject navigation adapter into components\n * Provides backward compatibility with class components\n */\nexport function withNavigationAdapter<P extends object>(\n  Component: React.ComponentType<P & { navigation: NavigationAdapter }>\n): React.FC<P> {\n  return (props: P) => {\n    const navigation = useNavigationAdapter();\n    return <Component {...props} navigation={navigation} />;\n  };\n}\n\n/**\n * Hook to get route params (works with both navigation systems)\n */\nexport function useRouteParams<T = any>(): T {\n  if (expoRouterHooks) {\n    return expoRouterHooks.useLocalSearchParams() as T;\n  }\n  // Will be provided by NavigationContainer route prop\n  return {} as T;\n}\n\n/**\n * Compatibility wrapper for screens\n * Normalizes props between expo-router and react-navigation\n */\nexport function createScreenWrapper(\n  Screen: React.ComponentType<any>,\n  options?: {\n    title?: (params?: any) => string;\n    headerShown?: boolean;\n  }\n) {\n  return function WrappedScreen(props: any) {\n    const params = useRouteParams();\n    const navigation = props.navigation || useNavigationAdapter();\n    \n    useEffect(() => {\n      if (options && navigation.setOptions) {\n        const screenOptions: any = {\n          headerShown: options.headerShown !== false,\n        };\n        \n        if (options.title) {\n          screenOptions.title = options.title(params);\n        }\n        \n        navigation.setOptions(screenOptions);\n      }\n    }, [navigation, params]);\n    \n    return <Screen {...props} {...params} navigation={navigation} />;\n  };\n}\n\n/**\n * Check if running in expo-router environment\n */\nexport function isExpoRouter(): boolean {\n  return expoRouter !== null;\n}\n\n/**\n * Export for type checking\n */\nexport type { NavigationAdapter as Navigation };\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,14 @@
1
+ import React from 'react';
2
+ export interface AudioVisualizerProps {
3
+ audioLevel: number;
4
+ barCount?: number;
5
+ barColor?: string;
6
+ style?: any;
7
+ }
8
+ export declare const AudioVisualizer: React.FC<AudioVisualizerProps>;
9
+ export declare const AudioLevelIndicator: React.FC<{
10
+ audioLevel: number;
11
+ size?: number;
12
+ color?: string;
13
+ }>;
14
+ export default AudioVisualizer;
@@ -0,0 +1,123 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.default = exports.AudioVisualizer = exports.AudioLevelIndicator = void 0;
7
+ var _react = _interopRequireDefault(require("react"));
8
+ var _reactNative = require("react-native");
9
+ function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
10
+ /**
11
+ * Audio Level Visualization Component
12
+ * Shows real-time audio levels with animated bars
13
+ * Works on Web, iOS, and Android
14
+ */
15
+
16
+ /**
17
+ * Audio Visualizer Component
18
+ * Displays animated bars representing audio input level
19
+ */
20
+ const AudioVisualizer = ({
21
+ audioLevel,
22
+ barCount = 5,
23
+ barColor = '#0000ff',
24
+ style
25
+ }) => {
26
+ // Create animated values for each bar
27
+ const animatedValues = _react.default.useMemo(() => Array.from({
28
+ length: barCount
29
+ }, () => new _reactNative.Animated.Value(0.2)), [barCount]);
30
+
31
+ // Animate bars based on audio level
32
+ _react.default.useEffect(() => {
33
+ const normalizedLevel = Math.min(100, Math.max(0, audioLevel)) / 100;
34
+ animatedValues.forEach((animValue, index) => {
35
+ // Each bar has slightly different timing for wave effect
36
+ const delay = index * 50;
37
+ const targetHeight = 0.2 + normalizedLevel * 0.8 * (Math.random() * 0.3 + 0.7);
38
+ _reactNative.Animated.timing(animValue, {
39
+ toValue: targetHeight,
40
+ duration: 100,
41
+ delay,
42
+ useNativeDriver: false
43
+ }).start();
44
+ });
45
+ }, [audioLevel, animatedValues]);
46
+ return /*#__PURE__*/_react.default.createElement(_reactNative.View, {
47
+ style: [styles.container, style]
48
+ }, animatedValues.map((animValue, index) => /*#__PURE__*/_react.default.createElement(_reactNative.Animated.View, {
49
+ key: index,
50
+ style: [styles.bar, {
51
+ backgroundColor: barColor,
52
+ height: animValue.interpolate({
53
+ inputRange: [0, 1],
54
+ outputRange: ['20%', '100%']
55
+ })
56
+ }]
57
+ })));
58
+ };
59
+
60
+ /**
61
+ * Circular Audio Level Indicator
62
+ * Shows audio level as a pulsing circle
63
+ */
64
+ exports.AudioVisualizer = AudioVisualizer;
65
+ const AudioLevelIndicator = ({
66
+ audioLevel,
67
+ size = 80,
68
+ color = '#0000ff'
69
+ }) => {
70
+ const scale = _react.default.useMemo(() => new _reactNative.Animated.Value(1), []);
71
+ _react.default.useEffect(() => {
72
+ const normalizedLevel = Math.min(100, Math.max(0, audioLevel)) / 100;
73
+ const targetScale = 1 + normalizedLevel * 0.3;
74
+ _reactNative.Animated.spring(scale, {
75
+ toValue: targetScale,
76
+ tension: 50,
77
+ friction: 3,
78
+ useNativeDriver: true
79
+ }).start();
80
+ }, [audioLevel, scale]);
81
+ return /*#__PURE__*/_react.default.createElement(_reactNative.View, {
82
+ style: [indicatorStyles.indicatorContainer, {
83
+ width: size,
84
+ height: size
85
+ }]
86
+ }, /*#__PURE__*/_react.default.createElement(_reactNative.Animated.View, {
87
+ style: [indicatorStyles.indicator, {
88
+ backgroundColor: color,
89
+ transform: [{
90
+ scale
91
+ }],
92
+ opacity: 0.7
93
+ }]
94
+ }));
95
+ };
96
+ exports.AudioLevelIndicator = AudioLevelIndicator;
97
+ const styles = _reactNative.StyleSheet.create({
98
+ container: {
99
+ flexDirection: 'row',
100
+ alignItems: 'center',
101
+ justifyContent: 'center',
102
+ height: 60,
103
+ gap: 4
104
+ },
105
+ bar: {
106
+ width: 4,
107
+ borderRadius: 2,
108
+ minHeight: '20%'
109
+ }
110
+ });
111
+ const indicatorStyles = _reactNative.StyleSheet.create({
112
+ indicatorContainer: {
113
+ justifyContent: 'center',
114
+ alignItems: 'center'
115
+ },
116
+ indicator: {
117
+ width: '100%',
118
+ height: '100%',
119
+ borderRadius: 999
120
+ }
121
+ });
122
+ var _default = exports.default = AudioVisualizer;
123
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_react","_interopRequireDefault","require","_reactNative","e","__esModule","default","AudioVisualizer","audioLevel","barCount","barColor","style","animatedValues","React","useMemo","Array","from","length","Animated","Value","useEffect","normalizedLevel","Math","min","max","forEach","animValue","index","delay","targetHeight","random","timing","toValue","duration","useNativeDriver","start","createElement","View","styles","container","map","key","bar","backgroundColor","height","interpolate","inputRange","outputRange","exports","AudioLevelIndicator","size","color","scale","targetScale","spring","tension","friction","indicatorStyles","indicatorContainer","width","indicator","transform","opacity","StyleSheet","create","flexDirection","alignItems","justifyContent","gap","borderRadius","minHeight","_default"],"sources":["../src/audio-visualizer.tsx"],"sourcesContent":["/**\n * Audio Level Visualization Component\n * Shows real-time audio levels with animated bars\n * Works on Web, iOS, and Android\n */\n\nimport React from 'react';\nimport { View, Animated, StyleSheet } from 'react-native';\n\nexport interface AudioVisualizerProps {\n  audioLevel: number; // 0-100\n  barCount?: number;\n  barColor?: string;\n  style?: any;\n}\n\n/**\n * Audio Visualizer Component\n * Displays animated bars representing audio input level\n */\nexport const AudioVisualizer: React.FC<AudioVisualizerProps> = ({\n  audioLevel,\n  barCount = 5,\n  barColor = '#0000ff',\n  style,\n}) => {\n  // Create animated values for each bar\n  const animatedValues = React.useMemo(\n    () => Array.from({ length: barCount }, () => new Animated.Value(0.2)),\n    [barCount]\n  );\n\n  // Animate bars based on audio level\n  React.useEffect(() => {\n    const normalizedLevel = Math.min(100, Math.max(0, audioLevel)) / 100;\n\n    animatedValues.forEach((animValue, index) => {\n      // Each bar has slightly different timing for wave effect\n      const delay = index * 50;\n      const targetHeight = 0.2 + normalizedLevel * 0.8 * (Math.random() * 0.3 + 0.7);\n\n      Animated.timing(animValue, {\n        toValue: targetHeight,\n        duration: 100,\n        delay,\n        useNativeDriver: false,\n      }).start();\n    });\n  }, [audioLevel, animatedValues]);\n\n  return (\n    <View style={[styles.container, style]}>\n      {animatedValues.map((animValue, index) => (\n        <Animated.View\n          key={index}\n          style={[\n            styles.bar,\n            {\n              backgroundColor: barColor,\n              height: animValue.interpolate({\n                inputRange: [0, 1],\n                outputRange: ['20%', '100%'],\n              }),\n            },\n          ]}\n        />\n      ))}\n    </View>\n  );\n};\n\n/**\n * Circular Audio Level Indicator\n * Shows audio level as a pulsing circle\n */\nexport const AudioLevelIndicator: React.FC<{\n  audioLevel: number;\n  size?: number;\n  color?: string;\n}> = ({ audioLevel, size = 80, color = '#0000ff' }) => {\n  const scale = React.useMemo(() => new Animated.Value(1), []);\n\n  React.useEffect(() => {\n    const normalizedLevel = Math.min(100, Math.max(0, audioLevel)) / 100;\n    const targetScale = 1 + normalizedLevel * 0.3;\n\n    Animated.spring(scale, {\n      toValue: targetScale,\n      tension: 50,\n      friction: 3,\n      useNativeDriver: true,\n    }).start();\n  }, [audioLevel, scale]);\n\n  return (\n    <View style={[indicatorStyles.indicatorContainer, { width: size, height: size }]}>\n      <Animated.View\n        style={[\n          indicatorStyles.indicator,\n          {\n            backgroundColor: color,\n            transform: [{ scale }],\n            opacity: 0.7,\n          },\n        ]}\n      />\n    </View>\n  );\n};\n\nconst styles = StyleSheet.create({\n  container: {\n    flexDirection: 'row',\n    alignItems: 'center',\n    justifyContent: 'center',\n    height: 60,\n    gap: 4,\n  },\n  bar: {\n    width: 4,\n    borderRadius: 2,\n    minHeight: '20%',\n  },\n});\n\nconst indicatorStyles = StyleSheet.create({\n  indicatorContainer: {\n    justifyContent: 'center',\n    alignItems: 'center',\n  },\n  indicator: {\n    width: '100%',\n    height: '100%',\n    borderRadius: 999,\n  },\n});\n\nexport default AudioVisualizer;\n"],"mappings":"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","ignoreList":[]}
@@ -0,0 +1,27 @@
1
+ export interface CurrentSelectionRect {
2
+ x: number;
3
+ y: number;
4
+ width: number;
5
+ height: number;
6
+ }
7
+ export interface CurrentSelectionInterface {
8
+ className: string;
9
+ key: any;
10
+ rect: CurrentSelectionRect;
11
+ }
12
+ type CurrentSelectionOptions = {
13
+ tapSlopPx?: number;
14
+ blockedRects?: CurrentSelectionRect[];
15
+ };
16
+ export declare class CurrentContextError extends Error {
17
+ constructor(message: string);
18
+ }
19
+ export declare function pickNearestInterface(candidates: CurrentSelectionInterface[], clickPoint: {
20
+ x: number;
21
+ y: number;
22
+ }): CurrentSelectionInterface;
23
+ export declare function pickCurrentInterface(currentClassName: string, interfaces: CurrentSelectionInterface[], clickPoints: {
24
+ x: number;
25
+ y: number;
26
+ }[], options?: CurrentSelectionOptions): CurrentSelectionInterface;
27
+ export {};
@@ -0,0 +1,94 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.CurrentContextError = void 0;
7
+ exports.pickCurrentInterface = pickCurrentInterface;
8
+ exports.pickNearestInterface = pickNearestInterface;
9
+ class CurrentContextError extends Error {
10
+ constructor(message) {
11
+ super(message);
12
+ this.name = 'CurrentContextError';
13
+ }
14
+ }
15
+ exports.CurrentContextError = CurrentContextError;
16
+ function pointToRectDistanceSq(pointX, pointY, rect) {
17
+ const closestX = Math.max(rect.x, Math.min(pointX, rect.x + rect.width));
18
+ const closestY = Math.max(rect.y, Math.min(pointY, rect.y + rect.height));
19
+ return Math.pow(pointX - closestX, 2) + Math.pow(pointY - closestY, 2);
20
+ }
21
+ function pointHitsRect(pointX, pointY, rect, slopPx) {
22
+ const left = rect.x - slopPx;
23
+ const right = rect.x + rect.width + slopPx;
24
+ const top = rect.y - slopPx;
25
+ const bottom = rect.y + rect.height + slopPx;
26
+ return pointX >= left && pointX <= right && pointY >= top && pointY <= bottom;
27
+ }
28
+ function pointIsBlocked(pointX, pointY, blockedRects) {
29
+ for (const rect of blockedRects) {
30
+ if (pointHitsRect(pointX, pointY, rect, 0)) {
31
+ return true;
32
+ }
33
+ }
34
+ return false;
35
+ }
36
+ function pickNearestInterface(candidates, clickPoint) {
37
+ let closest = candidates[0];
38
+ let closestDistance = pointToRectDistanceSq(clickPoint.x, clickPoint.y, closest.rect);
39
+ for (let i = 1; i < candidates.length; i++) {
40
+ const distance = pointToRectDistanceSq(clickPoint.x, clickPoint.y, candidates[i].rect);
41
+ if (distance < closestDistance) {
42
+ closest = candidates[i];
43
+ closestDistance = distance;
44
+ }
45
+ }
46
+ console.log(`[Current] nearest match for tap (${clickPoint.x}, ${clickPoint.y}) -> ${closest.className} ${JSON.stringify(closest.key)} distance=${closestDistance}`);
47
+ return closest;
48
+ }
49
+ function pickCurrentInterface(currentClassName, interfaces, clickPoints, options = {}) {
50
+ const tapSlopPx = options.tapSlopPx ?? 14;
51
+ const blockedRects = options.blockedRects ?? [];
52
+ console.log(`[Current] resolving ${currentClassName}; interfaces=${interfaces.length}; clickPoints=${clickPoints.length}`);
53
+ console.log(`[Current] interfaces: ${interfaces.map(genieInterface => `${genieInterface.className}:${JSON.stringify(genieInterface.key)}@(${genieInterface.rect.x},${genieInterface.rect.y},${genieInterface.rect.width},${genieInterface.rect.height})`).join(" | ")}`);
54
+ const candidates = interfaces.filter(genieInterface => genieInterface.className === currentClassName);
55
+ console.log(`[Current] candidates for ${currentClassName}: ${candidates.map(genieInterface => `${JSON.stringify(genieInterface.key)}@(${genieInterface.rect.x},${genieInterface.rect.y},${genieInterface.rect.width},${genieInterface.rect.height})`).join(" | ") || "none"}`);
56
+ if (candidates.length === 0) {
57
+ throw new CurrentContextError(`No visible ${currentClassName} context is available on this screen.`);
58
+ }
59
+
60
+ // Resolution order:
61
+ // 1. If the user tapped while listening (for example on /probes), resolve the
62
+ // nearest visible wrapper of the requested class only.
63
+ // 2. Otherwise fall back to the largest visible wrapper of that class (for
64
+ // example the single Probe on /probes/[probeId]).
65
+ if (clickPoints.length > 0) {
66
+ for (let index = clickPoints.length - 1; index >= 0; index -= 1) {
67
+ const tap = clickPoints[index];
68
+ if (pointIsBlocked(tap.x, tap.y, blockedRects)) {
69
+ console.log(`[Current] skipping tap (${tap.x}, ${tap.y}) at index ${index}; occluded by voice UI`);
70
+ continue;
71
+ }
72
+ const tappedCandidates = candidates.filter(candidate => pointHitsRect(tap.x, tap.y, candidate.rect, tapSlopPx));
73
+ if (tappedCandidates.length === 0) {
74
+ console.log(`[Current] skipping tap (${tap.x}, ${tap.y}) at index ${index}; no ${currentClassName} hit`);
75
+ continue;
76
+ }
77
+ console.log(`[Current] using tap (${tap.x}, ${tap.y}) at index ${index}; matched ${tappedCandidates.length} candidate(s)`);
78
+ return pickNearestInterface(tappedCandidates, tap);
79
+ }
80
+ console.log(`[Current] no captured taps hit visible ${currentClassName}; falling back to largest visible candidate`);
81
+ }
82
+ let result = candidates[0];
83
+ let biggestArea = result.rect.width * result.rect.height;
84
+ for (let i = 1; i < candidates.length; i++) {
85
+ const area = candidates[i].rect.width * candidates[i].rect.height;
86
+ if (area > biggestArea) {
87
+ result = candidates[i];
88
+ biggestArea = area;
89
+ }
90
+ }
91
+ console.log(`[Current] no tap available; using largest visible ${currentClassName} ${JSON.stringify(result.key)} area=${biggestArea}`);
92
+ return result;
93
+ }
94
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["CurrentContextError","Error","constructor","message","name","exports","pointToRectDistanceSq","pointX","pointY","rect","closestX","Math","max","x","min","width","closestY","y","height","pow","pointHitsRect","slopPx","left","right","top","bottom","pointIsBlocked","blockedRects","pickNearestInterface","candidates","clickPoint","closest","closestDistance","i","length","distance","console","log","className","JSON","stringify","key","pickCurrentInterface","currentClassName","interfaces","clickPoints","options","tapSlopPx","map","genieInterface","join","filter","index","tap","tappedCandidates","candidate","result","biggestArea","area"],"sources":["../src/current-selection.ts"],"sourcesContent":["export interface CurrentSelectionRect {\n  x: number;\n  y: number;\n  width: number;\n  height: number;\n}\n\nexport interface CurrentSelectionInterface {\n  className: string;\n  key: any;\n  rect: CurrentSelectionRect;\n}\n\ntype CurrentSelectionOptions = {\n  tapSlopPx?: number;\n  blockedRects?: CurrentSelectionRect[];\n};\n\nexport class CurrentContextError extends Error {\n  constructor(message: string) {\n    super(message);\n    this.name = 'CurrentContextError';\n  }\n}\n\nfunction pointToRectDistanceSq(\n  pointX: number,\n  pointY: number,\n  rect: CurrentSelectionRect,\n): number {\n  const closestX = Math.max(rect.x, Math.min(pointX, rect.x + rect.width));\n  const closestY = Math.max(rect.y, Math.min(pointY, rect.y + rect.height));\n  return Math.pow(pointX - closestX, 2) + Math.pow(pointY - closestY, 2);\n}\n\nfunction pointHitsRect(\n  pointX: number,\n  pointY: number,\n  rect: CurrentSelectionRect,\n  slopPx: number,\n): boolean {\n  const left = rect.x - slopPx;\n  const right = rect.x + rect.width + slopPx;\n  const top = rect.y - slopPx;\n  const bottom = rect.y + rect.height + slopPx;\n  return pointX >= left && pointX <= right && pointY >= top && pointY <= bottom;\n}\n\nfunction pointIsBlocked(\n  pointX: number,\n  pointY: number,\n  blockedRects: CurrentSelectionRect[],\n): boolean {\n  for (const rect of blockedRects) {\n    if (pointHitsRect(pointX, pointY, rect, 0)) {\n      return true;\n    }\n  }\n  return false;\n}\n\nexport function pickNearestInterface(\n  candidates: CurrentSelectionInterface[],\n  clickPoint: { x: number; y: number },\n): CurrentSelectionInterface {\n  let closest = candidates[0];\n  let closestDistance = pointToRectDistanceSq(\n    clickPoint.x,\n    clickPoint.y,\n    closest.rect,\n  );\n\n  for (let i = 1; i < candidates.length; i++) {\n    const distance = pointToRectDistanceSq(\n      clickPoint.x,\n      clickPoint.y,\n      candidates[i].rect,\n    );\n    if (distance < closestDistance) {\n      closest = candidates[i];\n      closestDistance = distance;\n    }\n  }\n\n  console.log(\n    `[Current] nearest match for tap (${clickPoint.x}, ${clickPoint.y}) -> ${closest.className} ${JSON.stringify(closest.key)} distance=${closestDistance}`,\n  );\n  return closest;\n}\n\nexport function pickCurrentInterface(\n  currentClassName: string,\n  interfaces: CurrentSelectionInterface[],\n  clickPoints: { x: number; y: number }[],\n  options: CurrentSelectionOptions = {},\n): CurrentSelectionInterface {\n  const tapSlopPx = options.tapSlopPx ?? 14;\n  const blockedRects = options.blockedRects ?? [];\n  console.log(\n    `[Current] resolving ${currentClassName}; interfaces=${interfaces.length}; clickPoints=${clickPoints.length}`,\n  );\n  console.log(\n    `[Current] interfaces: ${interfaces\n      .map(\n        (genieInterface) =>\n          `${genieInterface.className}:${JSON.stringify(genieInterface.key)}@(${genieInterface.rect.x},${genieInterface.rect.y},${genieInterface.rect.width},${genieInterface.rect.height})`,\n      )\n      .join(\" | \")}`,\n  );\n  const candidates = interfaces.filter(\n    (genieInterface) => genieInterface.className === currentClassName,\n  );\n\n  console.log(\n    `[Current] candidates for ${currentClassName}: ${candidates\n      .map(\n        (genieInterface) =>\n          `${JSON.stringify(genieInterface.key)}@(${genieInterface.rect.x},${genieInterface.rect.y},${genieInterface.rect.width},${genieInterface.rect.height})`,\n      )\n      .join(\" | \") || \"none\"}`,\n  );\n\n  if (candidates.length === 0) {\n    throw new CurrentContextError(\n      `No visible ${currentClassName} context is available on this screen.`,\n    );\n  }\n\n  // Resolution order:\n  // 1. If the user tapped while listening (for example on /probes), resolve the\n  //    nearest visible wrapper of the requested class only.\n  // 2. Otherwise fall back to the largest visible wrapper of that class (for\n  //    example the single Probe on /probes/[probeId]).\n  if (clickPoints.length > 0) {\n    for (let index = clickPoints.length - 1; index >= 0; index -= 1) {\n      const tap = clickPoints[index];\n      if (pointIsBlocked(tap.x, tap.y, blockedRects)) {\n        console.log(\n          `[Current] skipping tap (${tap.x}, ${tap.y}) at index ${index}; occluded by voice UI`,\n        );\n        continue;\n      }\n\n      const tappedCandidates = candidates.filter((candidate) =>\n        pointHitsRect(tap.x, tap.y, candidate.rect, tapSlopPx),\n      );\n      if (tappedCandidates.length === 0) {\n        console.log(\n          `[Current] skipping tap (${tap.x}, ${tap.y}) at index ${index}; no ${currentClassName} hit`,\n        );\n        continue;\n      }\n\n      console.log(\n        `[Current] using tap (${tap.x}, ${tap.y}) at index ${index}; matched ${tappedCandidates.length} candidate(s)`,\n      );\n      return pickNearestInterface(tappedCandidates, tap);\n    }\n\n    console.log(\n      `[Current] no captured taps hit visible ${currentClassName}; falling back to largest visible candidate`,\n    );\n  }\n\n  let result = candidates[0];\n  let biggestArea = result.rect.width * result.rect.height;\n\n  for (let i = 1; i < candidates.length; i++) {\n    const area = candidates[i].rect.width * candidates[i].rect.height;\n    if (area > biggestArea) {\n      result = candidates[i];\n      biggestArea = area;\n    }\n  }\n\n  console.log(\n    `[Current] no tap available; using largest visible ${currentClassName} ${JSON.stringify(result.key)} area=${biggestArea}`,\n  );\n  return result;\n}\n"],"mappings":";;;;;;;;AAkBO,MAAMA,mBAAmB,SAASC,KAAK,CAAC;EAC7CC,WAAWA,CAACC,OAAe,EAAE;IAC3B,KAAK,CAACA,OAAO,CAAC;IACd,IAAI,CAACC,IAAI,GAAG,qBAAqB;EACnC;AACF;AAACC,OAAA,CAAAL,mBAAA,GAAAA,mBAAA;AAED,SAASM,qBAAqBA,CAC5BC,MAAc,EACdC,MAAc,EACdC,IAA0B,EAClB;EACR,MAAMC,QAAQ,GAAGC,IAAI,CAACC,GAAG,CAACH,IAAI,CAACI,CAAC,EAAEF,IAAI,CAACG,GAAG,CAACP,MAAM,EAAEE,IAAI,CAACI,CAAC,GAAGJ,IAAI,CAACM,KAAK,CAAC,CAAC;EACxE,MAAMC,QAAQ,GAAGL,IAAI,CAACC,GAAG,CAACH,IAAI,CAACQ,CAAC,EAAEN,IAAI,CAACG,GAAG,CAACN,MAAM,EAAEC,IAAI,CAACQ,CAAC,GAAGR,IAAI,CAACS,MAAM,CAAC,CAAC;EACzE,OAAOP,IAAI,CAACQ,GAAG,CAACZ,MAAM,GAAGG,QAAQ,EAAE,CAAC,CAAC,GAAGC,IAAI,CAACQ,GAAG,CAACX,MAAM,GAAGQ,QAAQ,EAAE,CAAC,CAAC;AACxE;AAEA,SAASI,aAAaA,CACpBb,MAAc,EACdC,MAAc,EACdC,IAA0B,EAC1BY,MAAc,EACL;EACT,MAAMC,IAAI,GAAGb,IAAI,CAACI,CAAC,GAAGQ,MAAM;EAC5B,MAAME,KAAK,GAAGd,IAAI,CAACI,CAAC,GAAGJ,IAAI,CAACM,KAAK,GAAGM,MAAM;EAC1C,MAAMG,GAAG,GAAGf,IAAI,CAACQ,CAAC,GAAGI,MAAM;EAC3B,MAAMI,MAAM,GAAGhB,IAAI,CAACQ,CAAC,GAAGR,IAAI,CAACS,MAAM,GAAGG,MAAM;EAC5C,OAAOd,MAAM,IAAIe,IAAI,IAAIf,MAAM,IAAIgB,KAAK,IAAIf,MAAM,IAAIgB,GAAG,IAAIhB,MAAM,IAAIiB,MAAM;AAC/E;AAEA,SAASC,cAAcA,CACrBnB,MAAc,EACdC,MAAc,EACdmB,YAAoC,EAC3B;EACT,KAAK,MAAMlB,IAAI,IAAIkB,YAAY,EAAE;IAC/B,IAAIP,aAAa,CAACb,MAAM,EAAEC,MAAM,EAAEC,IAAI,EAAE,CAAC,CAAC,EAAE;MAC1C,OAAO,IAAI;IACb;EACF;EACA,OAAO,KAAK;AACd;AAEO,SAASmB,oBAAoBA,CAClCC,UAAuC,EACvCC,UAAoC,EACT;EAC3B,IAAIC,OAAO,GAAGF,UAAU,CAAC,CAAC,CAAC;EAC3B,IAAIG,eAAe,GAAG1B,qBAAqB,CACzCwB,UAAU,CAACjB,CAAC,EACZiB,UAAU,CAACb,CAAC,EACZc,OAAO,CAACtB,IACV,CAAC;EAED,KAAK,IAAIwB,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGJ,UAAU,CAACK,MAAM,EAAED,CAAC,EAAE,EAAE;IAC1C,MAAME,QAAQ,GAAG7B,qBAAqB,CACpCwB,UAAU,CAACjB,CAAC,EACZiB,UAAU,CAACb,CAAC,EACZY,UAAU,CAACI,CAAC,CAAC,CAACxB,IAChB,CAAC;IACD,IAAI0B,QAAQ,GAAGH,eAAe,EAAE;MAC9BD,OAAO,GAAGF,UAAU,CAACI,CAAC,CAAC;MACvBD,eAAe,GAAGG,QAAQ;IAC5B;EACF;EAEAC,OAAO,CAACC,GAAG,CACT,oCAAoCP,UAAU,CAACjB,CAAC,KAAKiB,UAAU,CAACb,CAAC,QAAQc,OAAO,CAACO,SAAS,IAAIC,IAAI,CAACC,SAAS,CAACT,OAAO,CAACU,GAAG,CAAC,aAAaT,eAAe,EACvJ,CAAC;EACD,OAAOD,OAAO;AAChB;AAEO,SAASW,oBAAoBA,CAClCC,gBAAwB,EACxBC,UAAuC,EACvCC,WAAuC,EACvCC,OAAgC,GAAG,CAAC,CAAC,EACV;EAC3B,MAAMC,SAAS,GAAGD,OAAO,CAACC,SAAS,IAAI,EAAE;EACzC,MAAMpB,YAAY,GAAGmB,OAAO,CAACnB,YAAY,IAAI,EAAE;EAC/CS,OAAO,CAACC,GAAG,CACT,uBAAuBM,gBAAgB,gBAAgBC,UAAU,CAACV,MAAM,iBAAiBW,WAAW,CAACX,MAAM,EAC7G,CAAC;EACDE,OAAO,CAACC,GAAG,CACT,yBAAyBO,UAAU,CAChCI,GAAG,CACDC,cAAc,IACb,GAAGA,cAAc,CAACX,SAAS,IAAIC,IAAI,CAACC,SAAS,CAACS,cAAc,CAACR,GAAG,CAAC,KAAKQ,cAAc,CAACxC,IAAI,CAACI,CAAC,IAAIoC,cAAc,CAACxC,IAAI,CAACQ,CAAC,IAAIgC,cAAc,CAACxC,IAAI,CAACM,KAAK,IAAIkC,cAAc,CAACxC,IAAI,CAACS,MAAM,GACnL,CAAC,CACAgC,IAAI,CAAC,KAAK,CAAC,EAChB,CAAC;EACD,MAAMrB,UAAU,GAAGe,UAAU,CAACO,MAAM,CACjCF,cAAc,IAAKA,cAAc,CAACX,SAAS,KAAKK,gBACnD,CAAC;EAEDP,OAAO,CAACC,GAAG,CACT,4BAA4BM,gBAAgB,KAAKd,UAAU,CACxDmB,GAAG,CACDC,cAAc,IACb,GAAGV,IAAI,CAACC,SAAS,CAACS,cAAc,CAACR,GAAG,CAAC,KAAKQ,cAAc,CAACxC,IAAI,CAACI,CAAC,IAAIoC,cAAc,CAACxC,IAAI,CAACQ,CAAC,IAAIgC,cAAc,CAACxC,IAAI,CAACM,KAAK,IAAIkC,cAAc,CAACxC,IAAI,CAACS,MAAM,GACvJ,CAAC,CACAgC,IAAI,CAAC,KAAK,CAAC,IAAI,MAAM,EAC1B,CAAC;EAED,IAAIrB,UAAU,CAACK,MAAM,KAAK,CAAC,EAAE;IAC3B,MAAM,IAAIlC,mBAAmB,CAC3B,cAAc2C,gBAAgB,uCAChC,CAAC;EACH;;EAEA;EACA;EACA;EACA;EACA;EACA,IAAIE,WAAW,CAACX,MAAM,GAAG,CAAC,EAAE;IAC1B,KAAK,IAAIkB,KAAK,GAAGP,WAAW,CAACX,MAAM,GAAG,CAAC,EAAEkB,KAAK,IAAI,CAAC,EAAEA,KAAK,IAAI,CAAC,EAAE;MAC/D,MAAMC,GAAG,GAAGR,WAAW,CAACO,KAAK,CAAC;MAC9B,IAAI1B,cAAc,CAAC2B,GAAG,CAACxC,CAAC,EAAEwC,GAAG,CAACpC,CAAC,EAAEU,YAAY,CAAC,EAAE;QAC9CS,OAAO,CAACC,GAAG,CACT,2BAA2BgB,GAAG,CAACxC,CAAC,KAAKwC,GAAG,CAACpC,CAAC,cAAcmC,KAAK,wBAC/D,CAAC;QACD;MACF;MAEA,MAAME,gBAAgB,GAAGzB,UAAU,CAACsB,MAAM,CAAEI,SAAS,IACnDnC,aAAa,CAACiC,GAAG,CAACxC,CAAC,EAAEwC,GAAG,CAACpC,CAAC,EAAEsC,SAAS,CAAC9C,IAAI,EAAEsC,SAAS,CACvD,CAAC;MACD,IAAIO,gBAAgB,CAACpB,MAAM,KAAK,CAAC,EAAE;QACjCE,OAAO,CAACC,GAAG,CACT,2BAA2BgB,GAAG,CAACxC,CAAC,KAAKwC,GAAG,CAACpC,CAAC,cAAcmC,KAAK,QAAQT,gBAAgB,MACvF,CAAC;QACD;MACF;MAEAP,OAAO,CAACC,GAAG,CACT,wBAAwBgB,GAAG,CAACxC,CAAC,KAAKwC,GAAG,CAACpC,CAAC,cAAcmC,KAAK,aAAaE,gBAAgB,CAACpB,MAAM,eAChG,CAAC;MACD,OAAON,oBAAoB,CAAC0B,gBAAgB,EAAED,GAAG,CAAC;IACpD;IAEAjB,OAAO,CAACC,GAAG,CACT,0CAA0CM,gBAAgB,6CAC5D,CAAC;EACH;EAEA,IAAIa,MAAM,GAAG3B,UAAU,CAAC,CAAC,CAAC;EAC1B,IAAI4B,WAAW,GAAGD,MAAM,CAAC/C,IAAI,CAACM,KAAK,GAAGyC,MAAM,CAAC/C,IAAI,CAACS,MAAM;EAExD,KAAK,IAAIe,CAAC,GAAG,CAAC,EAAEA,CAAC,GAAGJ,UAAU,CAACK,MAAM,EAAED,CAAC,EAAE,EAAE;IAC1C,MAAMyB,IAAI,GAAG7B,UAAU,CAACI,CAAC,CAAC,CAACxB,IAAI,CAACM,KAAK,GAAGc,UAAU,CAACI,CAAC,CAAC,CAACxB,IAAI,CAACS,MAAM;IACjE,IAAIwC,IAAI,GAAGD,WAAW,EAAE;MACtBD,MAAM,GAAG3B,UAAU,CAACI,CAAC,CAAC;MACtBwB,WAAW,GAAGC,IAAI;IACpB;EACF;EAEAtB,OAAO,CAACC,GAAG,CACT,qDAAqDM,gBAAgB,IAAIJ,IAAI,CAACC,SAAS,CAACgB,MAAM,CAACf,GAAG,CAAC,SAASgB,WAAW,EACzH,CAAC;EACD,OAAOD,MAAM;AACf","ignoreList":[]}
@@ -0,0 +1,19 @@
1
+ export type GenieUserFacingErrorType = "info" | "error" | "success" | "warning";
2
+ export type GenieUserFacingErrorParams = {
3
+ minimalText: string;
4
+ fullText?: string;
5
+ type?: GenieUserFacingErrorType;
6
+ code?: string;
7
+ shouldSpeak?: boolean;
8
+ cause?: unknown;
9
+ };
10
+ export declare class GenieUserFacingError extends Error {
11
+ code?: string;
12
+ minimalText: string;
13
+ fullText: string;
14
+ type: GenieUserFacingErrorType;
15
+ shouldSpeak?: boolean;
16
+ cause?: unknown;
17
+ constructor({ minimalText, fullText, type, code, shouldSpeak, cause, }: GenieUserFacingErrorParams);
18
+ }
19
+ export declare function isGenieUserFacingError(error: unknown): error is GenieUserFacingError;
package/dist/errors.js ADDED
@@ -0,0 +1,37 @@
1
+ "use strict";
2
+
3
+ Object.defineProperty(exports, "__esModule", {
4
+ value: true
5
+ });
6
+ exports.GenieUserFacingError = void 0;
7
+ exports.isGenieUserFacingError = isGenieUserFacingError;
8
+ class GenieUserFacingError extends Error {
9
+ constructor({
10
+ minimalText,
11
+ fullText,
12
+ type = "error",
13
+ code,
14
+ shouldSpeak,
15
+ cause
16
+ }) {
17
+ super(fullText || minimalText);
18
+ this.code = void 0;
19
+ this.minimalText = void 0;
20
+ this.fullText = void 0;
21
+ this.type = void 0;
22
+ this.shouldSpeak = void 0;
23
+ this.cause = void 0;
24
+ this.name = "GenieUserFacingError";
25
+ this.code = code;
26
+ this.minimalText = minimalText;
27
+ this.fullText = fullText || minimalText;
28
+ this.type = type;
29
+ this.shouldSpeak = shouldSpeak;
30
+ this.cause = cause;
31
+ }
32
+ }
33
+ exports.GenieUserFacingError = GenieUserFacingError;
34
+ function isGenieUserFacingError(error) {
35
+ return error instanceof GenieUserFacingError;
36
+ }
37
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJuYW1lcyI6WyJHZW5pZVVzZXJGYWNpbmdFcnJvciIsIkVycm9yIiwiY29uc3RydWN0b3IiLCJtaW5pbWFsVGV4dCIsImZ1bGxUZXh0IiwidHlwZSIsImNvZGUiLCJzaG91bGRTcGVhayIsImNhdXNlIiwibmFtZSIsImV4cG9ydHMiLCJpc0dlbmllVXNlckZhY2luZ0Vycm9yIiwiZXJyb3IiXSwic291cmNlcyI6WyIuLi9zcmMvZXJyb3JzLnRzIl0sInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIEdlbmllVXNlckZhY2luZ0Vycm9yVHlwZSA9IFwiaW5mb1wiIHwgXCJlcnJvclwiIHwgXCJzdWNjZXNzXCIgfCBcIndhcm5pbmdcIjtcblxuZXhwb3J0IHR5cGUgR2VuaWVVc2VyRmFjaW5nRXJyb3JQYXJhbXMgPSB7XG4gIG1pbmltYWxUZXh0OiBzdHJpbmc7XG4gIGZ1bGxUZXh0Pzogc3RyaW5nO1xuICB0eXBlPzogR2VuaWVVc2VyRmFjaW5nRXJyb3JUeXBlO1xuICBjb2RlPzogc3RyaW5nO1xuICBzaG91bGRTcGVhaz86IGJvb2xlYW47XG4gIGNhdXNlPzogdW5rbm93bjtcbn07XG5cbmV4cG9ydCBjbGFzcyBHZW5pZVVzZXJGYWNpbmdFcnJvciBleHRlbmRzIEVycm9yIHtcbiAgY29kZT86IHN0cmluZztcbiAgbWluaW1hbFRleHQ6IHN0cmluZztcbiAgZnVsbFRleHQ6IHN0cmluZztcbiAgdHlwZTogR2VuaWVVc2VyRmFjaW5nRXJyb3JUeXBlO1xuICBzaG91bGRTcGVhaz86IGJvb2xlYW47XG4gIG92ZXJyaWRlIGNhdXNlPzogdW5rbm93bjtcblxuICBjb25zdHJ1Y3Rvcih7XG4gICAgbWluaW1hbFRleHQsXG4gICAgZnVsbFRleHQsXG4gICAgdHlwZSA9IFwiZXJyb3JcIixcbiAgICBjb2RlLFxuICAgIHNob3VsZFNwZWFrLFxuICAgIGNhdXNlLFxuICB9OiBHZW5pZVVzZXJGYWNpbmdFcnJvclBhcmFtcykge1xuICAgIHN1cGVyKGZ1bGxUZXh0IHx8IG1pbmltYWxUZXh0KTtcbiAgICB0aGlzLm5hbWUgPSBcIkdlbmllVXNlckZhY2luZ0Vycm9yXCI7XG4gICAgdGhpcy5jb2RlID0gY29kZTtcbiAgICB0aGlzLm1pbmltYWxUZXh0ID0gbWluaW1hbFRleHQ7XG4gICAgdGhpcy5mdWxsVGV4dCA9IGZ1bGxUZXh0IHx8IG1pbmltYWxUZXh0O1xuICAgIHRoaXMudHlwZSA9IHR5cGU7XG4gICAgdGhpcy5zaG91bGRTcGVhayA9IHNob3VsZFNwZWFrO1xuICAgIHRoaXMuY2F1c2UgPSBjYXVzZTtcbiAgfVxufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNHZW5pZVVzZXJGYWNpbmdFcnJvcihlcnJvcjogdW5rbm93bik6IGVycm9yIGlzIEdlbmllVXNlckZhY2luZ0Vycm9yIHtcbiAgcmV0dXJuIGVycm9yIGluc3RhbmNlb2YgR2VuaWVVc2VyRmFjaW5nRXJyb3I7XG59XG4iXSwibWFwcGluZ3MiOiI7Ozs7Ozs7QUFXTyxNQUFNQSxvQkFBb0IsU0FBU0MsS0FBSyxDQUFDO0VBUTlDQyxXQUFXQSxDQUFDO0lBQ1ZDLFdBQVc7SUFDWEMsUUFBUTtJQUNSQyxJQUFJLEdBQUcsT0FBTztJQUNkQyxJQUFJO0lBQ0pDLFdBQVc7SUFDWEM7RUFDMEIsQ0FBQyxFQUFFO0lBQzdCLEtBQUssQ0FBQ0osUUFBUSxJQUFJRCxXQUFXLENBQUM7SUFBQyxLQWZqQ0csSUFBSTtJQUFBLEtBQ0pILFdBQVc7SUFBQSxLQUNYQyxRQUFRO0lBQUEsS0FDUkMsSUFBSTtJQUFBLEtBQ0pFLFdBQVc7SUFBQSxLQUNGQyxLQUFLO0lBV1osSUFBSSxDQUFDQyxJQUFJLEdBQUcsc0JBQXNCO0lBQ2xDLElBQUksQ0FBQ0gsSUFBSSxHQUFHQSxJQUFJO0lBQ2hCLElBQUksQ0FBQ0gsV0FBVyxHQUFHQSxXQUFXO0lBQzlCLElBQUksQ0FBQ0MsUUFBUSxHQUFHQSxRQUFRLElBQUlELFdBQVc7SUFDdkMsSUFBSSxDQUFDRSxJQUFJLEdBQUdBLElBQUk7SUFDaEIsSUFBSSxDQUFDRSxXQUFXLEdBQUdBLFdBQVc7SUFDOUIsSUFBSSxDQUFDQyxLQUFLLEdBQUdBLEtBQUs7RUFDcEI7QUFDRjtBQUFDRSxPQUFBLENBQUFWLG9CQUFBLEdBQUFBLG9CQUFBO0FBRU0sU0FBU1csc0JBQXNCQSxDQUFDQyxLQUFjLEVBQWlDO0VBQ3BGLE9BQU9BLEtBQUssWUFBWVosb0JBQW9CO0FBQzlDIiwiaWdub3JlTGlzdCI6W119
@@ -0,0 +1,66 @@
1
+ import { HelperClass } from "@garrix82/reactgenie-dsl";
2
+ import "reflect-metadata";
3
+ import { int } from "@garrix82/reactgenie-dsl";
4
+ export declare class DateTime extends HelperClass {
5
+ private _date;
6
+ year: int;
7
+ month: int;
8
+ day: int;
9
+ dayOfWeek: int;
10
+ hour: int;
11
+ minute: int;
12
+ second: int;
13
+ static sunday: int;
14
+ static monday: int;
15
+ static tuesday: int;
16
+ static wednesday: int;
17
+ static thursday: int;
18
+ static friday: int;
19
+ static saturday: int;
20
+ private updateDate;
21
+ static now(): DateTime;
22
+ static today(): DateTime;
23
+ static fromDate(date: Date): DateTime;
24
+ constructor({ year, month, day, hour, minute, second, }: {
25
+ year?: int;
26
+ month?: int;
27
+ day?: int;
28
+ hour?: int;
29
+ minute?: int;
30
+ second?: int;
31
+ });
32
+ static setup(): void;
33
+ static compare(a: DateTime, b: DateTime): number;
34
+ static fromString(data: string): DateTime;
35
+ static CreateDatetime({ year, month, day, hour, minute, second, }: {
36
+ year?: int;
37
+ month?: int;
38
+ day?: int;
39
+ hour?: int;
40
+ minute?: int;
41
+ second?: int;
42
+ }): DateTime;
43
+ addDateOffset({ year, month, day, hour, minute, second, }: {
44
+ year?: int;
45
+ month?: int;
46
+ day?: int;
47
+ hour?: int;
48
+ minute?: int;
49
+ second?: int;
50
+ }): DateTime;
51
+ setDate({ year, month, day, hour, minute, second, day_of_the_week, }: {
52
+ year?: int;
53
+ month?: int;
54
+ day?: int;
55
+ hour?: int;
56
+ minute?: int;
57
+ second?: int;
58
+ day_of_the_week?: int;
59
+ }): DateTime;
60
+ toString(): string;
61
+ getDate(): Date;
62
+ static Examples: {
63
+ user_utterance: string;
64
+ example_parsed: string;
65
+ }[];
66
+ }