feat: add debug script inject

pull/193/head
moonrailgun 1 year ago
parent 3de7fe2c69
commit 4eedaf87da

@ -27,6 +27,32 @@ export function generateInstallPluginScript() {
return raw; return raw;
} }
export function generateDebugScript() {
const inner = `function main() {
console.error = (...args) => {
window.ReactNativeWebView.postMessage(
JSON.stringify({
_isTailchat: true,
type: 'console:error',
payload: args,
})
);
};
console.log = (...args) => {
window.ReactNativeWebView.postMessage(
JSON.stringify({
_isTailchat: true,
type: 'console:log',
payload: JSON.stringify(args),
})
);
};
}`;
const raw = `(${inner})()`;
return raw;
}
export function generateInjectedScript(): string { export function generateInjectedScript(): string {
return [generateDeviceInfo(), generatePostMessageScript()].join(';'); return [generateDeviceInfo(), generatePostMessageScript()].join(';');
} }

@ -1,10 +1,12 @@
import type WebView from 'react-native-webview'; import type WebView from 'react-native-webview';
import { generateInstallPluginScript } from '.'; import { generateDebugScript, generateInstallPluginScript } from '.';
import { useUIStore } from '../../store/ui'; import { useUIStore } from '../../store/ui';
import type { UserBaseInfo } from '../../types'; import type { UserBaseInfo } from '../../types';
import { initNotificationEnv, showNotification } from '../notifications'; import { initNotificationEnv, showNotification } from '../notifications';
// import { bindSocketEvent, createSocket } from '../socket'; // import { bindSocketEvent, createSocket } from '../socket';
import { AppState } from 'react-native'; import { AppState } from 'react-native';
import { ensureWebRTCPermission } from '../permissions';
import { isDev } from '../utils';
export function handleTailchatMessage( export function handleTailchatMessage(
type: string, type: string,
@ -15,6 +17,11 @@ export function handleTailchatMessage(
if (type === 'init') { if (type === 'init') {
webview.injectJavaScript(generateInstallPluginScript()); webview.injectJavaScript(generateInstallPluginScript());
if (isDev()) {
webview.injectJavaScript(generateDebugScript());
}
return; return;
} }
@ -36,6 +43,10 @@ export function handleTailchatMessage(
return; return;
} }
if (type === 'ensureWebRTCPermission') {
ensureWebRTCPermission();
}
if (type === 'bindWebsocket') { if (type === 'bindWebsocket') {
const userInfo = payload.userInfo as UserBaseInfo; const userInfo = payload.userInfo as UserBaseInfo;

Loading…
Cancel
Save