From f5f27a2e5870a646ddf40a698f9949b47aa485d1 Mon Sep 17 00:00:00 2001 From: lin onetwo Date: Fri, 29 Nov 2024 17:37:29 +0800 Subject: [PATCH] refactor: injectJavascript in the source html --- src/pages/WikiWebView/CustomWebview.tsx | 11 ++++++----- src/pages/WikiWebView/WikiViewer.tsx | 6 +++--- .../SQLiteTiddlersReadStream.ts | 2 +- .../streamChunksPreloadScript.ts | 2 -- src/pages/WikiWebView/useWikiWebViewNotification.ts | 3 +-- src/services/ImportService/index.ts | 2 +- src/services/WikiStorageService/index.ts | 5 ++--- 7 files changed, 14 insertions(+), 17 deletions(-) diff --git a/src/pages/WikiWebView/CustomWebview.tsx b/src/pages/WikiWebView/CustomWebview.tsx index 54d1fac..5c88829 100644 --- a/src/pages/WikiWebView/CustomWebview.tsx +++ b/src/pages/WikiWebView/CustomWebview.tsx @@ -1,12 +1,13 @@ import React, { MutableRefObject, PureComponent } from 'react'; import { Text } from 'react-native-paper'; import { WebView, WebViewMessageEvent } from 'react-native-webview'; +import type { WebViewErrorEvent, WebViewNavigationEvent } from 'react-native-webview/lib/RNCWebViewNativeComponent'; import { FAKE_USER_AGENT } from '../../constants/webview'; interface CustomWebViewProps { backgroundColor: string; - injectedJavaScriptBeforeContentLoaded: string; - onLoadEnd: () => void; + injectedJavaScript: string; + onLoadEnd: (event: WebViewNavigationEvent | WebViewErrorEvent) => void; onLoadStart: () => void; onMessageReference: MutableRefObject<(event: WebViewMessageEvent) => void>; preferredLanguage: string | undefined | null; @@ -23,7 +24,7 @@ export class CustomWebView extends PureComponent { onLoadEnd, onLoadStart, onMessageReference, - injectedJavaScriptBeforeContentLoaded, + injectedJavaScript, triggerFullReload, } = this.props; @@ -47,12 +48,13 @@ export class CustomWebView extends PureComponent { mixedContentMode='always' allowsAirPlayForMediaPlayback allowsFullscreenVideo + javaScriptEnabled userAgent={FAKE_USER_AGENT} // add DOCTYPE at load time to prevent Quirks Mode source={{ html: `
`, + }">
Loading...`, /** * Add baseUrl to fix `SecurityError: Failed to read the 'localStorage' property from 'Window': Access is denied for this document.` * @url https://github.com/react-native-webview/react-native-webview/issues/1635#issuecomment-1021425071 @@ -75,7 +77,6 @@ export class CustomWebView extends PureComponent { onLoadStart={onLoadStart} onMessage={onMessageReference.current} ref={webViewReference} - injectedJavaScriptBeforeContentLoaded={injectedJavaScriptBeforeContentLoaded} webviewDebuggingEnabled={true /* Open chrome://inspect/#devices , or Development menu on Safari to debug the WebView. https://github.com/react-native-webview/react-native-webview/blob/master/docs/Debugging.md#debugging-webview-contents */} /> ); diff --git a/src/pages/WikiWebView/WikiViewer.tsx b/src/pages/WikiWebView/WikiViewer.tsx index d8f7f66..0ec9561 100644 --- a/src/pages/WikiWebView/WikiViewer.tsx +++ b/src/pages/WikiWebView/WikiViewer.tsx @@ -1,7 +1,7 @@ /* eslint-disable @typescript-eslint/strict-boolean-expressions */ import useThrottledCallback from 'beautiful-react-hooks/useThrottledCallback'; import { useCallback, useEffect, useMemo, useState } from 'react'; -import { Dimensions } from 'react-native'; +import { Dimensions, Platform } from 'react-native'; import { MD3Colors, ProgressBar, Text, useTheme } from 'react-native-paper'; import { webviewPreloadedJS as ipcCatWebviewPreloadedJS } from 'react-native-postmessage-cat'; import { styled } from 'styled-components/native'; @@ -140,10 +140,10 @@ export function WikiViewer({ wikiWorkspace, webviewSideReceiver, quickLoad }: Wi onLoadEnd={onLoadEnd} onLoadStart={onLoadStart} onMessageReference={onMessageReference} - injectedJavaScriptBeforeContentLoaded={preloadScript} + injectedJavaScript={preloadScript} triggerFullReload={triggerFullReload} /> ); -}; +} diff --git a/src/pages/WikiWebView/useStreamChunksToWebView/SQLiteTiddlersReadStream.ts b/src/pages/WikiWebView/useStreamChunksToWebView/SQLiteTiddlersReadStream.ts index 7cd3a02..17988de 100644 --- a/src/pages/WikiWebView/useStreamChunksToWebView/SQLiteTiddlersReadStream.ts +++ b/src/pages/WikiWebView/useStreamChunksToWebView/SQLiteTiddlersReadStream.ts @@ -1,7 +1,7 @@ /* eslint-disable unicorn/no-null */ import { max } from 'drizzle-orm'; import { ExpoSQLiteDatabase } from 'drizzle-orm/expo-sqlite'; -import { SQLiteDatabase, SQLiteStatement } from 'expo-sqlite/next'; +import { SQLiteDatabase, SQLiteStatement } from 'expo-sqlite'; import { Readable } from 'readable-stream'; import { sqliteServiceService } from '../../../services/SQLiteService'; import { TiddlersSQLModel } from '../../../services/SQLiteService/orm'; diff --git a/src/pages/WikiWebView/useStreamChunksToWebView/streamChunksPreloadScript.ts b/src/pages/WikiWebView/useStreamChunksToWebView/streamChunksPreloadScript.ts index 2989dde..441fb34 100644 --- a/src/pages/WikiWebView/useStreamChunksToWebView/streamChunksPreloadScript.ts +++ b/src/pages/WikiWebView/useStreamChunksToWebView/streamChunksPreloadScript.ts @@ -47,7 +47,6 @@ export enum OnStreamChunksToWebViewEventTypes { break; } case OnStreamChunksToWebViewEventTypes.CHECK_RECEIVER_READY: { - // @ts-ignore window.service?.wikiHookService?.setWebviewReceiverReady?.(); break; } @@ -130,7 +129,6 @@ export enum OnStreamChunksToWebViewEventTypes { try { script.parentNode.replaceChild(newScript, script); } catch (error) { - // FIXME: can't catch error `SyntaxError: Can't create duplicate variable: 'A'` on iOS console.error(`Faile to refresh script tag with error ${(error as Error).message}: newScript, script`, newScript, script, error); } } diff --git a/src/pages/WikiWebView/useWikiWebViewNotification.ts b/src/pages/WikiWebView/useWikiWebViewNotification.ts index 76e4c3f..9f5b062 100644 --- a/src/pages/WikiWebView/useWikiWebViewNotification.ts +++ b/src/pages/WikiWebView/useWikiWebViewNotification.ts @@ -74,7 +74,6 @@ export function useWikiWebViewNotification({ id }: { id?: string }) { } async function registerForPushNotifications() { - let token: string | undefined; if (Platform.OS === 'android') { await setNotificationChannelAsync('default', { name: 'default', @@ -104,7 +103,7 @@ async function registerForPushNotifications() { if (finalStatus !== PermissionStatus.GRANTED) { alert('Failed to get push token for push notification!'); } - token = (await getDevicePushTokenAsync()).data as string; + const token = (await getDevicePushTokenAsync()).data as string; setNotificationHandler({ handleNotification: async () => ({ diff --git a/src/services/ImportService/index.ts b/src/services/ImportService/index.ts index 4377f48..b67ce3b 100644 --- a/src/services/ImportService/index.ts +++ b/src/services/ImportService/index.ts @@ -1,5 +1,5 @@ /* eslint-disable @typescript-eslint/strict-boolean-expressions */ -import { SQLiteDatabase, SQLiteStatement } from 'expo-sqlite/next'; +import { SQLiteDatabase, SQLiteStatement } from 'expo-sqlite'; import { Dispatch, SetStateAction } from 'react'; import { Writable } from 'readable-stream'; import Chain, { chain } from 'stream-chain'; diff --git a/src/services/WikiStorageService/index.ts b/src/services/WikiStorageService/index.ts index 1b3938b..fac8f83 100644 --- a/src/services/WikiStorageService/index.ts +++ b/src/services/WikiStorageService/index.ts @@ -5,7 +5,6 @@ import * as fs from 'expo-file-system'; import { Observable } from 'rxjs'; import type { IChangedTiddlers, ITiddlerFieldsParam } from 'tiddlywiki'; import { getWikiTiddlerPathByTitle } from '../../constants/paths'; -import i18n from '../../i18n'; import { useConfigStore } from '../../store/config'; import { useServerStore } from '../../store/server'; import { IWikiWorkspace } from '../../store/workspace'; @@ -18,7 +17,7 @@ import { getFullSaveTiddlers } from './ignoredTiddler'; /** * Service that can be used to save/load wiki data * - * - proxy by `src/pages/WikiWebView/WikiStorageService/registerWikiStorageServiceOnWebView.ts` to be `window.service.wikiStorageService` + * - proxy by `react-native-postmessage-cat` to be `window.service.wikiStorageService` * - then used in `plugins/src/expo-file-system-syncadaptor/file-system-syncadaptor.ts` inside webview * * Don't forget to register method in WikiStorageServiceIPCDescriptor. Otherwise you will get `window.service.wikiStorageService.methodName is not a function` error. @@ -124,7 +123,7 @@ export class WikiStorageService { orderBy: desc(TiddlerChangeSQLModel.timestamp), }); - if (recentUpdate !== undefined && recentUpdate.operation === TiddlersLogOperation.UPDATE && recentUpdate.title === title) { + if (recentUpdate !== undefined && recentUpdate.operation as TiddlersLogOperation === TiddlersLogOperation.UPDATE && recentUpdate.title === title) { // If we are frequently update same title, then update the timestamp of last update, instead of put a new UPDATE log. await transaction.update(TiddlerChangeSQLModel) .set({ timestamp: newOperation.timestamp })