@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,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":"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","ignoreList":[]}
|
package/dist/errors.d.ts
ADDED
|
@@ -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
|
+
}
|