mirror of
https://github.com/RoboSats/robosats.git
synced 2024-12-14 11:26:24 +00:00
0689377f2c
* Android app confuration and fixes * Adding ignore files * Prettier * Asset load * Run prettier * Add upload Web.bundle directory as build artifact * CR Co-authored-by: Reckless_Satoshi <reckless.satoshi@protonmail.com>
76 lines
2.5 KiB
TypeScript
76 lines
2.5 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)}
|
|
overScrollMode='never'
|
|
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;
|