From 4abd88e2136fe8c667a1931c5c906bbf9053cb9f Mon Sep 17 00:00:00 2001 From: PalmDevs Date: Thu, 5 Dec 2024 18:34:09 +0700 Subject: [PATCH] fix(libraries/react/jsx): persist patch on iOS regardless of listener count --- libraries/react/src/jsx.ts | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/libraries/react/src/jsx.ts b/libraries/react/src/jsx.ts index b6ac84e..97cf357 100644 --- a/libraries/react/src/jsx.ts +++ b/libraries/react/src/jsx.ts @@ -2,7 +2,7 @@ import { ReactJSXRuntime } from '@revenge-mod/modules/common' import { patcher } from './shared' import type { ComponentProps, ElementType, ReactElement } from 'react' -import { StyleSheet, type ViewProps } from 'react-native' +import { Platform, StyleSheet, type ViewProps } from 'react-native' const styles = StyleSheet.create({ hidden: { @@ -11,6 +11,7 @@ const styles = StyleSheet.create({ }) let patched = false +const persistentPatch = Platform.OS === 'ios' const beforeCallbacks: Record> = {} const afterCallbacks: Record> = {} @@ -59,18 +60,19 @@ const patchCallback = ( return tree } +// Without setTimeout, causes app freeze +setTimeout(() => persistentPatch && patchJsxRuntimeIfNotPatched()) + const patchJsxRuntimeIfNotPatched = () => { if (patched) return patched = true - // Without this timeout, patching succeeds, but results in app freeze (similar to freezing Metro module) - setTimeout(() => { - patcher.instead(ReactJSXRuntime, 'jsx', patchCallback, 'patchJsxRuntime') - patcher.instead(ReactJSXRuntime, 'jsxs', patchCallback, 'patchJsxRuntime') - }) + patcher.instead(ReactJSXRuntime, 'jsx', patchCallback, 'patchJsxRuntime') + patcher.instead(ReactJSXRuntime, 'jsxs', patchCallback, 'patchJsxRuntime') } const unpatchIfNoListenersLeft = () => { + if (persistentPatch) return if (Object.values(beforeCallbacks).some(set => set.size) || Object.values(afterCallbacks).some(set => set.size)) return