mirror of
https://github.com/RoboSats/robosats.git
synced 2025-01-18 20:21:35 +00:00
75 lines
2.4 KiB
TypeScript
75 lines
2.4 KiB
TypeScript
|
import React, { useRef } from 'react';
|
||
|
import { WebView, WebViewMessageEvent } from 'react-native-webview';
|
||
|
import { SafeAreaView, Text, Platform } from 'react-native';
|
||
|
import { torClient } from './services/Tor';
|
||
|
|
||
|
const App = () => {
|
||
|
const webViewRef = useRef<WebView>();
|
||
|
const uri = (Platform.OS === 'android' ? 'file:///android_asset/' : '') + 'Web.bundle/index.html';
|
||
|
|
||
|
const injectMessage = (id: string, data: object) => {
|
||
|
const json = JSON.stringify(data);
|
||
|
webViewRef.current?.injectJavaScript(
|
||
|
`(function() {window.NativeRobosats.onMessageResolve(${id}, ${json});})();`,
|
||
|
);
|
||
|
};
|
||
|
|
||
|
const onMessage = async (event: WebViewMessageEvent) => {
|
||
|
const data = JSON.parse(event.nativeEvent.data);
|
||
|
if (data.category === 'http') {
|
||
|
if (data.type === 'get') {
|
||
|
torClient.get(data.path).then((response: object) => {
|
||
|
injectMessage(data.id, response);
|
||
|
});
|
||
|
} else if (data.type === 'post') {
|
||
|
torClient.post(data.path, data.body, data.headers).then((response: object) => {
|
||
|
injectMessage(data.id, response);
|
||
|
});
|
||
|
} else if (data.type === 'delete') {
|
||
|
torClient.delete(data.path, data.headers).then((response: object) => {
|
||
|
injectMessage(data.id, response);
|
||
|
});
|
||
|
} else if (data.type === 'xhr') {
|
||
|
torClient.request(data.path).then((response: object) => {
|
||
|
injectMessage(data.id, response);
|
||
|
});
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
|
||
|
torClient.startDaemon();
|
||
|
|
||
|
return (
|
||
|
<SafeAreaView style={{ flex: 1 }}>
|
||
|
<WebView
|
||
|
source={{
|
||
|
uri,
|
||
|
}}
|
||
|
onMessage={onMessage}
|
||
|
// @ts-expect-error
|
||
|
ref={(ref) => (webViewRef.current = ref)}
|
||
|
javaScriptEnabled={true}
|
||
|
domStorageEnabled={true}
|
||
|
sharedCookiesEnabled={true}
|
||
|
thirdPartyCookiesEnabled={true}
|
||
|
originWhitelist={[uri]}
|
||
|
scalesPageToFit={true}
|
||
|
startInLoadingState={true}
|
||
|
mixedContentMode={'always'}
|
||
|
allowsInlineMediaPlayback={true}
|
||
|
allowsFullscreenVideo={false}
|
||
|
setBuiltInZoomControls={false}
|
||
|
allowingReadAccessToURL={uri}
|
||
|
allowFileAccess={true}
|
||
|
allowsBackForwardNavigationGestures={false}
|
||
|
mediaPlaybackRequiresUserAction={false}
|
||
|
allowsLinkPreview={false}
|
||
|
renderLoading={() => <Text>Loading RoboSats</Text>}
|
||
|
onError={(syntheticEvent) => <Text>{syntheticEvent.type}</Text>}
|
||
|
/>
|
||
|
</SafeAreaView>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default App;
|