react-native-screens 3.29.0 → 3.30.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (448) hide show
  1. package/README.md +7 -7
  2. package/RNScreens.podspec +3 -3
  3. package/android/CMakeLists.txt +27 -0
  4. package/android/build.gradle +21 -2
  5. package/android/src/fabric/java/com/swmansion/rnscreens/FabricEnabledViewGroup.kt +17 -14
  6. package/android/src/main/cpp/jni-adapter.cpp +110 -0
  7. package/android/src/main/java/com/swmansion/rnscreens/CustomSearchView.kt +13 -8
  8. package/android/src/main/java/com/swmansion/rnscreens/FragmentBackPressOverrider.kt +8 -8
  9. package/android/src/main/java/com/swmansion/rnscreens/ModalScreenViewManager.kt +12 -0
  10. package/android/src/main/java/com/swmansion/rnscreens/RNScreensPackage.kt +38 -5
  11. package/android/src/main/java/com/swmansion/rnscreens/Screen.kt +32 -42
  12. package/android/src/main/java/com/swmansion/rnscreens/ScreenContainer.kt +76 -48
  13. package/android/src/main/java/com/swmansion/rnscreens/ScreenFragment.kt +38 -35
  14. package/android/src/main/java/com/swmansion/rnscreens/ScreenStack.kt +43 -37
  15. package/android/src/main/java/com/swmansion/rnscreens/ScreenStackFragment.kt +23 -23
  16. package/android/src/main/java/com/swmansion/rnscreens/ScreenStackHeaderConfig.kt +73 -71
  17. package/android/src/main/java/com/swmansion/rnscreens/ScreenStackHeaderConfigViewManager.kt +3 -3
  18. package/android/src/main/java/com/swmansion/rnscreens/ScreenStackHeaderSubview.kt +5 -5
  19. package/android/src/main/java/com/swmansion/rnscreens/ScreenStackHeaderSubviewManager.kt +3 -3
  20. package/android/src/main/java/com/swmansion/rnscreens/ScreenStackViewManager.kt +3 -3
  21. package/android/src/main/java/com/swmansion/rnscreens/ScreenViewManager.kt +4 -4
  22. package/android/src/main/java/com/swmansion/rnscreens/ScreenWindowTraits.kt +13 -16
  23. package/android/src/main/java/com/swmansion/rnscreens/ScreensModule.kt +105 -0
  24. package/android/src/main/java/com/swmansion/rnscreens/ScreensShadowNode.kt +2 -2
  25. package/android/src/main/java/com/swmansion/rnscreens/SearchBarManager.kt +1 -0
  26. package/android/src/main/java/com/swmansion/rnscreens/SearchBarView.kt +14 -10
  27. package/android/src/main/java/com/swmansion/rnscreens/SearchViewFormatter.kt +8 -8
  28. package/android/src/main/java/com/swmansion/rnscreens/events/HeaderAttachedEvent.kt +3 -7
  29. package/android/src/main/java/com/swmansion/rnscreens/events/HeaderBackButtonClickedEvent.kt +4 -8
  30. package/android/src/main/java/com/swmansion/rnscreens/events/HeaderDetachedEvent.kt +3 -7
  31. package/android/src/main/java/com/swmansion/rnscreens/events/HeaderHeightChangeEvent.kt +3 -3
  32. package/android/src/main/java/com/swmansion/rnscreens/events/ScreenTransitionProgressEvent.kt +9 -13
  33. package/android/src/main/java/com/swmansion/rnscreens/events/SearchBarBlurEvent.kt +3 -7
  34. package/android/src/main/java/com/swmansion/rnscreens/events/SearchBarChangeTextEvent.kt +3 -7
  35. package/android/src/main/java/com/swmansion/rnscreens/events/SearchBarCloseEvent.kt +3 -7
  36. package/android/src/main/java/com/swmansion/rnscreens/events/SearchBarFocusEvent.kt +3 -7
  37. package/android/src/main/java/com/swmansion/rnscreens/events/SearchBarOpenEvent.kt +3 -7
  38. package/android/src/main/java/com/swmansion/rnscreens/events/SearchBarSearchButtonPressEvent.kt +3 -7
  39. package/android/src/main/jni/rnscreens.h +1 -0
  40. package/android/src/main/res/v33/anim-v33/rns_default_enter_in.xml +0 -1
  41. package/android/src/main/res/v33/anim-v33/rns_default_enter_out.xml +2 -2
  42. package/android/src/paper/java/com/swmansion/rnscreens/FabricEnabledViewGroup.kt +1 -1
  43. package/android/src/paper/java/com/swmansion/rnscreens/NativeScreensModuleSpec.java +32 -0
  44. package/common/cpp/react/renderer/components/rnscreens/RNSModalScreenComponentDescriptor.h +41 -0
  45. package/common/cpp/react/renderer/components/rnscreens/RNSModalScreenShadowNode.cpp +15 -0
  46. package/common/cpp/react/renderer/components/rnscreens/RNSModalScreenShadowNode.h +31 -0
  47. package/common/cpp/react/renderer/components/rnscreens/RNSScreenShadowNode.cpp +6 -0
  48. package/common/cpp/react/renderer/components/rnscreens/RNSScreenShadowNode.h +1 -5
  49. package/common/cpp/react/renderer/components/rnscreens/RNSScreenState.cpp +1 -1
  50. package/common/cpp/react/renderer/components/rnscreens/RNSScreenState.h +8 -3
  51. package/cpp/RNScreensTurboModule.cpp +107 -0
  52. package/cpp/RNScreensTurboModule.h +43 -0
  53. package/gesture-handler/package.json +6 -0
  54. package/ios/RNSConvert.h +2 -0
  55. package/ios/RNSConvert.mm +5 -2
  56. package/ios/RNSEnums.h +1 -0
  57. package/ios/RNSModalScreen.h +8 -0
  58. package/ios/RNSModalScreen.mm +36 -0
  59. package/ios/RNSModule.h +19 -0
  60. package/ios/RNSModule.mm +174 -0
  61. package/ios/RNSScreen.h +4 -1
  62. package/ios/RNSScreen.mm +48 -26
  63. package/ios/RNSScreenStack.h +6 -0
  64. package/ios/RNSScreenStack.mm +81 -15
  65. package/ios/RNSScreenStackAnimator.mm +89 -1
  66. package/ios/RNSScreenStackHeaderConfig.mm +7 -1
  67. package/ios/RNSScreenWindowTraits.h +1 -1
  68. package/ios/RNSScreenWindowTraits.mm +24 -50
  69. package/ios/RNSSearchBar.mm +24 -0
  70. package/ios/utils/RNSUIBarButtonItem.h +2 -0
  71. package/lib/commonjs/TransitionProgressContext.js +3 -4
  72. package/lib/commonjs/TransitionProgressContext.js.map +1 -1
  73. package/lib/commonjs/components/FullWindowOverlay.js +28 -0
  74. package/lib/commonjs/components/FullWindowOverlay.js.map +1 -0
  75. package/lib/commonjs/components/FullWindowOverlay.web.js +9 -0
  76. package/lib/commonjs/components/FullWindowOverlay.web.js.map +1 -0
  77. package/lib/commonjs/components/Screen.js +161 -0
  78. package/lib/commonjs/components/Screen.js.map +1 -0
  79. package/lib/commonjs/components/Screen.web.js +46 -0
  80. package/lib/commonjs/components/Screen.web.js.map +1 -0
  81. package/lib/commonjs/components/ScreenContainer.js +33 -0
  82. package/lib/commonjs/components/ScreenContainer.js.map +1 -0
  83. package/lib/commonjs/components/ScreenContainer.web.js +11 -0
  84. package/lib/commonjs/components/ScreenContainer.web.js.map +1 -0
  85. package/lib/commonjs/components/ScreenStack.js +45 -0
  86. package/lib/commonjs/components/ScreenStack.js.map +1 -0
  87. package/lib/commonjs/components/ScreenStack.web.js +9 -0
  88. package/lib/commonjs/components/ScreenStack.web.js.map +1 -0
  89. package/lib/commonjs/components/ScreenStackHeaderConfig.js +53 -0
  90. package/lib/commonjs/components/ScreenStackHeaderConfig.js.map +1 -0
  91. package/lib/commonjs/components/ScreenStackHeaderConfig.web.js +27 -0
  92. package/lib/commonjs/components/ScreenStackHeaderConfig.web.js.map +1 -0
  93. package/lib/commonjs/components/SearchBar.js +59 -0
  94. package/lib/commonjs/components/SearchBar.js.map +1 -0
  95. package/lib/commonjs/components/SearchBar.web.js +11 -0
  96. package/lib/commonjs/components/SearchBar.web.js.map +1 -0
  97. package/lib/commonjs/components/helpers/DelayedFreeze.js +32 -0
  98. package/lib/commonjs/components/helpers/DelayedFreeze.js.map +1 -0
  99. package/lib/commonjs/core.js +41 -0
  100. package/lib/commonjs/core.js.map +1 -0
  101. package/lib/commonjs/fabric/FullWindowOverlayNativeComponent.js +1 -2
  102. package/lib/commonjs/fabric/FullWindowOverlayNativeComponent.js.map +1 -1
  103. package/lib/commonjs/fabric/ModalScreenNativeComponent.js +13 -0
  104. package/lib/commonjs/fabric/ModalScreenNativeComponent.js.map +1 -0
  105. package/lib/commonjs/fabric/NativeScreensModule.js +10 -0
  106. package/lib/commonjs/fabric/NativeScreensModule.js.map +1 -0
  107. package/lib/commonjs/fabric/NativeScreensModule.web.js +8 -0
  108. package/lib/commonjs/fabric/NativeScreensModule.web.js.map +1 -0
  109. package/lib/commonjs/fabric/ScreenContainerNativeComponent.js +1 -2
  110. package/lib/commonjs/fabric/ScreenContainerNativeComponent.js.map +1 -1
  111. package/lib/commonjs/fabric/ScreenNativeComponent.js +1 -2
  112. package/lib/commonjs/fabric/ScreenNativeComponent.js.map +1 -1
  113. package/lib/commonjs/fabric/ScreenNavigationContainerNativeComponent.js +1 -2
  114. package/lib/commonjs/fabric/ScreenNavigationContainerNativeComponent.js.map +1 -1
  115. package/lib/commonjs/fabric/ScreenStackHeaderConfigNativeComponent.js +1 -2
  116. package/lib/commonjs/fabric/ScreenStackHeaderConfigNativeComponent.js.map +1 -1
  117. package/lib/commonjs/fabric/ScreenStackHeaderSubviewNativeComponent.js +1 -2
  118. package/lib/commonjs/fabric/ScreenStackHeaderSubviewNativeComponent.js.map +1 -1
  119. package/lib/commonjs/fabric/ScreenStackNativeComponent.js +1 -2
  120. package/lib/commonjs/fabric/ScreenStackNativeComponent.js.map +1 -1
  121. package/lib/commonjs/fabric/SearchBarNativeComponent.js +3 -5
  122. package/lib/commonjs/fabric/SearchBarNativeComponent.js.map +1 -1
  123. package/lib/commonjs/gesture-handler/GestureDetectorProvider.js +19 -0
  124. package/lib/commonjs/gesture-handler/GestureDetectorProvider.js.map +1 -0
  125. package/lib/commonjs/gesture-handler/RNScreensTurboModule.js +8 -0
  126. package/lib/commonjs/gesture-handler/RNScreensTurboModule.js.map +1 -0
  127. package/lib/commonjs/gesture-handler/ScreenGestureDetector.js +202 -0
  128. package/lib/commonjs/gesture-handler/ScreenGestureDetector.js.map +1 -0
  129. package/lib/commonjs/gesture-handler/constraints.js +64 -0
  130. package/lib/commonjs/gesture-handler/constraints.js.map +1 -0
  131. package/lib/commonjs/gesture-handler/defaults.js +38 -0
  132. package/lib/commonjs/gesture-handler/defaults.js.map +1 -0
  133. package/lib/commonjs/gesture-handler/fabricUtils.js +30 -0
  134. package/lib/commonjs/gesture-handler/fabricUtils.js.map +1 -0
  135. package/lib/commonjs/gesture-handler/fabricUtils.web.js +17 -0
  136. package/lib/commonjs/gesture-handler/fabricUtils.web.js.map +1 -0
  137. package/lib/commonjs/gesture-handler/index.js +14 -0
  138. package/lib/commonjs/gesture-handler/index.js.map +1 -0
  139. package/lib/commonjs/index.js +183 -100
  140. package/lib/commonjs/index.js.map +1 -1
  141. package/lib/commonjs/native-stack/contexts/GHContext.js +11 -0
  142. package/lib/commonjs/native-stack/contexts/GHContext.js.map +1 -0
  143. package/lib/commonjs/native-stack/index.js.map +1 -1
  144. package/lib/commonjs/native-stack/navigators/createNativeStackNavigator.js +20 -24
  145. package/lib/commonjs/native-stack/navigators/createNativeStackNavigator.js.map +1 -1
  146. package/lib/commonjs/native-stack/types.js.map +1 -1
  147. package/lib/commonjs/native-stack/utils/AnimatedHeaderHeightContext.js +3 -4
  148. package/lib/commonjs/native-stack/utils/AnimatedHeaderHeightContext.js.map +1 -1
  149. package/lib/commonjs/native-stack/utils/HeaderHeightContext.js +3 -4
  150. package/lib/commonjs/native-stack/utils/HeaderHeightContext.js.map +1 -1
  151. package/lib/commonjs/native-stack/utils/SafeAreaProviderCompat.js +2 -2
  152. package/lib/commonjs/native-stack/utils/SafeAreaProviderCompat.js.map +1 -1
  153. package/lib/commonjs/native-stack/utils/getDefaultHeaderHeight.js.map +1 -1
  154. package/lib/commonjs/native-stack/utils/getStatusBarHeight.js.map +1 -1
  155. package/lib/commonjs/native-stack/utils/useAnimatedHeaderHeight.js +2 -2
  156. package/lib/commonjs/native-stack/utils/useAnimatedHeaderHeight.js.map +1 -1
  157. package/lib/commonjs/native-stack/utils/useBackPressSubscription.js +2 -4
  158. package/lib/commonjs/native-stack/utils/useBackPressSubscription.js.map +1 -1
  159. package/lib/commonjs/native-stack/utils/useHeaderHeight.js +2 -2
  160. package/lib/commonjs/native-stack/utils/useHeaderHeight.js.map +1 -1
  161. package/lib/commonjs/native-stack/views/FontProcessor.js +1 -2
  162. package/lib/commonjs/native-stack/views/FontProcessor.js.map +1 -1
  163. package/lib/commonjs/native-stack/views/HeaderConfig.js +11 -7
  164. package/lib/commonjs/native-stack/views/HeaderConfig.js.map +1 -1
  165. package/lib/commonjs/native-stack/views/NativeStackView.js +50 -15
  166. package/lib/commonjs/native-stack/views/NativeStackView.js.map +1 -1
  167. package/lib/commonjs/reanimated/ReanimatedHeaderHeightContext.js +3 -4
  168. package/lib/commonjs/reanimated/ReanimatedHeaderHeightContext.js.map +1 -1
  169. package/lib/commonjs/reanimated/ReanimatedNativeStackScreen.js +6 -9
  170. package/lib/commonjs/reanimated/ReanimatedNativeStackScreen.js.map +1 -1
  171. package/lib/commonjs/reanimated/ReanimatedScreen.js +1 -2
  172. package/lib/commonjs/reanimated/ReanimatedScreen.js.map +1 -1
  173. package/lib/commonjs/reanimated/ReanimatedScreenProvider.js +6 -14
  174. package/lib/commonjs/reanimated/ReanimatedScreenProvider.js.map +1 -1
  175. package/lib/commonjs/reanimated/ReanimatedTransitionProgressContext.js +3 -4
  176. package/lib/commonjs/reanimated/ReanimatedTransitionProgressContext.js.map +1 -1
  177. package/lib/commonjs/reanimated/index.js.map +1 -1
  178. package/lib/commonjs/reanimated/useReanimatedHeaderHeight.js +2 -2
  179. package/lib/commonjs/reanimated/useReanimatedHeaderHeight.js.map +1 -1
  180. package/lib/commonjs/reanimated/useReanimatedTransitionProgress.js +2 -2
  181. package/lib/commonjs/reanimated/useReanimatedTransitionProgress.js.map +1 -1
  182. package/lib/commonjs/types.js.map +1 -1
  183. package/lib/commonjs/useTransitionProgress.js +2 -2
  184. package/lib/commonjs/useTransitionProgress.js.map +1 -1
  185. package/lib/commonjs/utils.js +2 -4
  186. package/lib/commonjs/utils.js.map +1 -1
  187. package/lib/module/TransitionProgressContext.js.map +1 -1
  188. package/lib/module/components/FullWindowOverlay.js +21 -0
  189. package/lib/module/components/FullWindowOverlay.js.map +1 -0
  190. package/lib/module/components/FullWindowOverlay.web.js +3 -0
  191. package/lib/module/components/FullWindowOverlay.web.js.map +1 -0
  192. package/lib/module/components/Screen.js +156 -0
  193. package/lib/module/components/Screen.js.map +1 -0
  194. package/lib/module/components/Screen.web.js +38 -0
  195. package/lib/module/components/Screen.web.js.map +1 -0
  196. package/lib/module/components/ScreenContainer.js +26 -0
  197. package/lib/module/components/ScreenContainer.js.map +1 -0
  198. package/lib/module/components/ScreenContainer.web.js +5 -0
  199. package/lib/module/components/ScreenContainer.web.js.map +1 -0
  200. package/lib/module/components/ScreenStack.js +40 -0
  201. package/lib/module/components/ScreenStack.js.map +1 -0
  202. package/lib/module/components/ScreenStack.web.js +3 -0
  203. package/lib/module/components/ScreenStack.web.js.map +1 -0
  204. package/lib/module/components/ScreenStackHeaderConfig.js +43 -0
  205. package/lib/module/components/ScreenStackHeaderConfig.js.map +1 -0
  206. package/lib/module/components/ScreenStackHeaderConfig.web.js +14 -0
  207. package/lib/module/components/ScreenStackHeaderConfig.web.js.map +1 -0
  208. package/lib/module/components/SearchBar.js +52 -0
  209. package/lib/module/components/SearchBar.js.map +1 -0
  210. package/lib/module/components/SearchBar.web.js +5 -0
  211. package/lib/module/components/SearchBar.web.js.map +1 -0
  212. package/lib/module/components/helpers/DelayedFreeze.js +25 -0
  213. package/lib/module/components/helpers/DelayedFreeze.js.map +1 -0
  214. package/lib/module/core.js +31 -0
  215. package/lib/module/core.js.map +1 -0
  216. package/lib/module/fabric/FullWindowOverlayNativeComponent.js.map +1 -1
  217. package/lib/module/fabric/ModalScreenNativeComponent.js +8 -0
  218. package/lib/module/fabric/ModalScreenNativeComponent.js.map +1 -0
  219. package/lib/module/fabric/NativeScreensModule.js +5 -0
  220. package/lib/module/fabric/NativeScreensModule.js.map +1 -0
  221. package/lib/module/fabric/NativeScreensModule.web.js +2 -0
  222. package/lib/module/fabric/NativeScreensModule.web.js.map +1 -0
  223. package/lib/module/fabric/ScreenContainerNativeComponent.js.map +1 -1
  224. package/lib/module/fabric/ScreenNativeComponent.js.map +1 -1
  225. package/lib/module/fabric/ScreenNavigationContainerNativeComponent.js.map +1 -1
  226. package/lib/module/fabric/ScreenStackHeaderConfigNativeComponent.js.map +1 -1
  227. package/lib/module/fabric/ScreenStackHeaderSubviewNativeComponent.js.map +1 -1
  228. package/lib/module/fabric/ScreenStackNativeComponent.js.map +1 -1
  229. package/lib/module/fabric/SearchBarNativeComponent.js +1 -1
  230. package/lib/module/fabric/SearchBarNativeComponent.js.map +1 -1
  231. package/lib/module/gesture-handler/GestureDetectorProvider.js +12 -0
  232. package/lib/module/gesture-handler/GestureDetectorProvider.js.map +1 -0
  233. package/lib/module/gesture-handler/RNScreensTurboModule.js +2 -0
  234. package/lib/module/gesture-handler/RNScreensTurboModule.js.map +1 -0
  235. package/lib/module/gesture-handler/ScreenGestureDetector.js +194 -0
  236. package/lib/module/gesture-handler/ScreenGestureDetector.js.map +1 -0
  237. package/lib/module/gesture-handler/constraints.js +56 -0
  238. package/lib/module/gesture-handler/constraints.js.map +1 -0
  239. package/lib/module/gesture-handler/defaults.js +32 -0
  240. package/lib/module/gesture-handler/defaults.js.map +1 -0
  241. package/lib/module/gesture-handler/fabricUtils.js +23 -0
  242. package/lib/module/gesture-handler/fabricUtils.js.map +1 -0
  243. package/lib/module/gesture-handler/fabricUtils.web.js +10 -0
  244. package/lib/module/gesture-handler/fabricUtils.web.js.map +1 -0
  245. package/lib/module/gesture-handler/index.js +5 -0
  246. package/lib/module/gesture-handler/index.js.map +1 -0
  247. package/lib/module/index.js +31 -64
  248. package/lib/module/index.js.map +1 -1
  249. package/lib/module/native-stack/contexts/GHContext.js +4 -0
  250. package/lib/module/native-stack/contexts/GHContext.js.map +1 -0
  251. package/lib/module/native-stack/index.js.map +1 -1
  252. package/lib/module/native-stack/navigators/createNativeStackNavigator.js +17 -20
  253. package/lib/module/native-stack/navigators/createNativeStackNavigator.js.map +1 -1
  254. package/lib/module/native-stack/types.js.map +1 -1
  255. package/lib/module/native-stack/utils/AnimatedHeaderHeightContext.js.map +1 -1
  256. package/lib/module/native-stack/utils/HeaderHeightContext.js.map +1 -1
  257. package/lib/module/native-stack/utils/SafeAreaProviderCompat.js.map +1 -1
  258. package/lib/module/native-stack/utils/getDefaultHeaderHeight.js.map +1 -1
  259. package/lib/module/native-stack/utils/getStatusBarHeight.js.map +1 -1
  260. package/lib/module/native-stack/utils/useAnimatedHeaderHeight.js.map +1 -1
  261. package/lib/module/native-stack/utils/useBackPressSubscription.js +2 -4
  262. package/lib/module/native-stack/utils/useBackPressSubscription.js.map +1 -1
  263. package/lib/module/native-stack/utils/useHeaderHeight.js.map +1 -1
  264. package/lib/module/native-stack/views/FontProcessor.js +1 -2
  265. package/lib/module/native-stack/views/FontProcessor.js.map +1 -1
  266. package/lib/module/native-stack/views/HeaderConfig.js +8 -5
  267. package/lib/module/native-stack/views/HeaderConfig.js.map +1 -1
  268. package/lib/module/native-stack/views/NativeStackView.js +49 -14
  269. package/lib/module/native-stack/views/NativeStackView.js.map +1 -1
  270. package/lib/module/reanimated/ReanimatedHeaderHeightContext.js.map +1 -1
  271. package/lib/module/reanimated/ReanimatedNativeStackScreen.js +2 -4
  272. package/lib/module/reanimated/ReanimatedNativeStackScreen.js.map +1 -1
  273. package/lib/module/reanimated/ReanimatedScreen.js.map +1 -1
  274. package/lib/module/reanimated/ReanimatedScreenProvider.js +6 -14
  275. package/lib/module/reanimated/ReanimatedScreenProvider.js.map +1 -1
  276. package/lib/module/reanimated/ReanimatedTransitionProgressContext.js.map +1 -1
  277. package/lib/module/reanimated/index.js.map +1 -1
  278. package/lib/module/reanimated/useReanimatedHeaderHeight.js.map +1 -1
  279. package/lib/module/reanimated/useReanimatedTransitionProgress.js.map +1 -1
  280. package/lib/module/types.js.map +1 -1
  281. package/lib/module/useTransitionProgress.js.map +1 -1
  282. package/lib/module/utils.js.map +1 -1
  283. package/lib/typescript/TransitionProgressContext.d.ts +1 -0
  284. package/lib/typescript/TransitionProgressContext.d.ts.map +1 -0
  285. package/lib/typescript/components/FullWindowOverlay.d.ts +6 -0
  286. package/lib/typescript/components/FullWindowOverlay.d.ts.map +1 -0
  287. package/lib/typescript/components/FullWindowOverlay.web.d.ts +6 -0
  288. package/lib/typescript/components/FullWindowOverlay.web.d.ts.map +1 -0
  289. package/lib/typescript/components/Screen.d.ts +20 -0
  290. package/lib/typescript/components/Screen.d.ts.map +1 -0
  291. package/lib/typescript/components/Screen.web.d.ts +11 -0
  292. package/lib/typescript/components/Screen.web.d.ts.map +1 -0
  293. package/lib/typescript/components/ScreenContainer.d.ts +7 -0
  294. package/lib/typescript/components/ScreenContainer.d.ts.map +1 -0
  295. package/lib/typescript/components/ScreenContainer.web.d.ts +5 -0
  296. package/lib/typescript/components/ScreenContainer.web.d.ts.map +1 -0
  297. package/lib/typescript/components/ScreenStack.d.ts +5 -0
  298. package/lib/typescript/components/ScreenStack.d.ts.map +1 -0
  299. package/lib/typescript/components/ScreenStack.web.d.ts +3 -0
  300. package/lib/typescript/components/ScreenStack.web.d.ts.map +1 -0
  301. package/lib/typescript/components/ScreenStackHeaderConfig.d.ts +13 -0
  302. package/lib/typescript/components/ScreenStackHeaderConfig.d.ts.map +1 -0
  303. package/lib/typescript/components/ScreenStackHeaderConfig.web.d.ts +13 -0
  304. package/lib/typescript/components/ScreenStackHeaderConfig.web.d.ts.map +1 -0
  305. package/lib/typescript/components/SearchBar.d.ts +26 -0
  306. package/lib/typescript/components/SearchBar.d.ts.map +1 -0
  307. package/lib/typescript/components/SearchBar.web.d.ts +5 -0
  308. package/lib/typescript/components/SearchBar.web.d.ts.map +1 -0
  309. package/lib/typescript/components/helpers/DelayedFreeze.d.ts +8 -0
  310. package/lib/typescript/components/helpers/DelayedFreeze.d.ts.map +1 -0
  311. package/lib/typescript/core.d.ts +7 -0
  312. package/lib/typescript/core.d.ts.map +1 -0
  313. package/lib/typescript/fabric/FullWindowOverlayNativeComponent.d.ts +1 -0
  314. package/lib/typescript/fabric/FullWindowOverlayNativeComponent.d.ts.map +1 -0
  315. package/lib/typescript/fabric/ModalScreenNativeComponent.d.ts +68 -0
  316. package/lib/typescript/fabric/ModalScreenNativeComponent.d.ts.map +1 -0
  317. package/lib/typescript/fabric/NativeScreensModule.d.ts +6 -0
  318. package/lib/typescript/fabric/NativeScreensModule.d.ts.map +1 -0
  319. package/lib/typescript/fabric/NativeScreensModule.web.d.ts +3 -0
  320. package/lib/typescript/fabric/NativeScreensModule.web.d.ts.map +1 -0
  321. package/lib/typescript/fabric/ScreenContainerNativeComponent.d.ts +1 -0
  322. package/lib/typescript/fabric/ScreenContainerNativeComponent.d.ts.map +1 -0
  323. package/lib/typescript/fabric/ScreenNativeComponent.d.ts +2 -1
  324. package/lib/typescript/fabric/ScreenNativeComponent.d.ts.map +1 -0
  325. package/lib/typescript/fabric/ScreenNavigationContainerNativeComponent.d.ts +1 -0
  326. package/lib/typescript/fabric/ScreenNavigationContainerNativeComponent.d.ts.map +1 -0
  327. package/lib/typescript/fabric/ScreenStackHeaderConfigNativeComponent.d.ts +1 -0
  328. package/lib/typescript/fabric/ScreenStackHeaderConfigNativeComponent.d.ts.map +1 -0
  329. package/lib/typescript/fabric/ScreenStackHeaderSubviewNativeComponent.d.ts +1 -0
  330. package/lib/typescript/fabric/ScreenStackHeaderSubviewNativeComponent.d.ts.map +1 -0
  331. package/lib/typescript/fabric/ScreenStackNativeComponent.d.ts +1 -0
  332. package/lib/typescript/fabric/ScreenStackNativeComponent.d.ts.map +1 -0
  333. package/lib/typescript/fabric/SearchBarNativeComponent.d.ts +3 -1
  334. package/lib/typescript/fabric/SearchBarNativeComponent.d.ts.map +1 -0
  335. package/lib/typescript/gesture-handler/GestureDetectorProvider.d.ts +5 -0
  336. package/lib/typescript/gesture-handler/GestureDetectorProvider.d.ts.map +1 -0
  337. package/lib/typescript/gesture-handler/RNScreensTurboModule.d.ts +13 -0
  338. package/lib/typescript/gesture-handler/RNScreensTurboModule.d.ts.map +1 -0
  339. package/lib/typescript/gesture-handler/ScreenGestureDetector.d.ts +5 -0
  340. package/lib/typescript/gesture-handler/ScreenGestureDetector.d.ts.map +1 -0
  341. package/lib/typescript/gesture-handler/constraints.d.ts +6 -0
  342. package/lib/typescript/gesture-handler/constraints.d.ts.map +1 -0
  343. package/lib/typescript/gesture-handler/defaults.d.ts +20 -0
  344. package/lib/typescript/gesture-handler/defaults.d.ts.map +1 -0
  345. package/lib/typescript/gesture-handler/fabricUtils.d.ts +8 -0
  346. package/lib/typescript/gesture-handler/fabricUtils.d.ts.map +1 -0
  347. package/lib/typescript/gesture-handler/fabricUtils.web.d.ts +6 -0
  348. package/lib/typescript/gesture-handler/fabricUtils.web.d.ts.map +1 -0
  349. package/lib/typescript/gesture-handler/index.d.ts +2 -0
  350. package/lib/typescript/gesture-handler/index.d.ts.map +1 -0
  351. package/lib/typescript/index.d.ts +11 -31
  352. package/lib/typescript/index.d.ts.map +1 -0
  353. package/lib/typescript/native-stack/contexts/GHContext.d.ts +4 -0
  354. package/lib/typescript/native-stack/contexts/GHContext.d.ts.map +1 -0
  355. package/lib/typescript/native-stack/index.d.ts +1 -0
  356. package/lib/typescript/native-stack/index.d.ts.map +1 -0
  357. package/lib/typescript/native-stack/navigators/createNativeStackNavigator.d.ts +1 -0
  358. package/lib/typescript/native-stack/navigators/createNativeStackNavigator.d.ts.map +1 -0
  359. package/lib/typescript/native-stack/types.d.ts +39 -2
  360. package/lib/typescript/native-stack/types.d.ts.map +1 -0
  361. package/lib/typescript/native-stack/utils/AnimatedHeaderHeightContext.d.ts +1 -0
  362. package/lib/typescript/native-stack/utils/AnimatedHeaderHeightContext.d.ts.map +1 -0
  363. package/lib/typescript/native-stack/utils/HeaderHeightContext.d.ts +1 -0
  364. package/lib/typescript/native-stack/utils/HeaderHeightContext.d.ts.map +1 -0
  365. package/lib/typescript/native-stack/utils/SafeAreaProviderCompat.d.ts +1 -0
  366. package/lib/typescript/native-stack/utils/SafeAreaProviderCompat.d.ts.map +1 -0
  367. package/lib/typescript/native-stack/utils/getDefaultHeaderHeight.d.ts +1 -0
  368. package/lib/typescript/native-stack/utils/getDefaultHeaderHeight.d.ts.map +1 -0
  369. package/lib/typescript/native-stack/utils/getStatusBarHeight.d.ts +1 -0
  370. package/lib/typescript/native-stack/utils/getStatusBarHeight.d.ts.map +1 -0
  371. package/lib/typescript/native-stack/utils/useAnimatedHeaderHeight.d.ts +1 -0
  372. package/lib/typescript/native-stack/utils/useAnimatedHeaderHeight.d.ts.map +1 -0
  373. package/lib/typescript/native-stack/utils/useBackPressSubscription.d.ts +1 -0
  374. package/lib/typescript/native-stack/utils/useBackPressSubscription.d.ts.map +1 -0
  375. package/lib/typescript/native-stack/utils/useHeaderHeight.d.ts +1 -0
  376. package/lib/typescript/native-stack/utils/useHeaderHeight.d.ts.map +1 -0
  377. package/lib/typescript/native-stack/views/FontProcessor.d.ts +1 -0
  378. package/lib/typescript/native-stack/views/FontProcessor.d.ts.map +1 -0
  379. package/lib/typescript/native-stack/views/HeaderConfig.d.ts +1 -0
  380. package/lib/typescript/native-stack/views/HeaderConfig.d.ts.map +1 -0
  381. package/lib/typescript/native-stack/views/NativeStackView.d.ts +1 -0
  382. package/lib/typescript/native-stack/views/NativeStackView.d.ts.map +1 -0
  383. package/lib/typescript/reanimated/ReanimatedHeaderHeightContext.d.ts +1 -0
  384. package/lib/typescript/reanimated/ReanimatedHeaderHeightContext.d.ts.map +1 -0
  385. package/lib/typescript/reanimated/ReanimatedNativeStackScreen.d.ts +2 -2
  386. package/lib/typescript/reanimated/ReanimatedNativeStackScreen.d.ts.map +1 -0
  387. package/lib/typescript/reanimated/ReanimatedScreen.d.ts +2 -2
  388. package/lib/typescript/reanimated/ReanimatedScreen.d.ts.map +1 -0
  389. package/lib/typescript/reanimated/ReanimatedScreenProvider.d.ts +1 -0
  390. package/lib/typescript/reanimated/ReanimatedScreenProvider.d.ts.map +1 -0
  391. package/lib/typescript/reanimated/ReanimatedTransitionProgressContext.d.ts +1 -0
  392. package/lib/typescript/reanimated/ReanimatedTransitionProgressContext.d.ts.map +1 -0
  393. package/lib/typescript/reanimated/index.d.ts +1 -0
  394. package/lib/typescript/reanimated/index.d.ts.map +1 -0
  395. package/lib/typescript/reanimated/useReanimatedHeaderHeight.d.ts +2 -3
  396. package/lib/typescript/reanimated/useReanimatedHeaderHeight.d.ts.map +1 -0
  397. package/lib/typescript/reanimated/useReanimatedTransitionProgress.d.ts +4 -9
  398. package/lib/typescript/reanimated/useReanimatedTransitionProgress.d.ts.map +1 -0
  399. package/lib/typescript/types.d.ts +11 -2
  400. package/lib/typescript/types.d.ts.map +1 -0
  401. package/lib/typescript/useTransitionProgress.d.ts +1 -0
  402. package/lib/typescript/useTransitionProgress.d.ts.map +1 -0
  403. package/lib/typescript/utils.d.ts +1 -0
  404. package/lib/typescript/utils.d.ts.map +1 -0
  405. package/native-stack/README.md +2 -1
  406. package/native-stack/package.json +1 -1
  407. package/package.json +17 -11
  408. package/react-native.config.js +2 -1
  409. package/reanimated/package.json +1 -1
  410. package/src/components/FullWindowOverlay.tsx +25 -0
  411. package/src/components/FullWindowOverlay.web.tsx +6 -0
  412. package/src/components/Screen.tsx +218 -0
  413. package/src/components/Screen.web.tsx +43 -0
  414. package/src/components/ScreenContainer.tsx +33 -0
  415. package/src/components/ScreenContainer.web.tsx +6 -0
  416. package/src/components/ScreenStack.tsx +41 -0
  417. package/src/components/ScreenStack.web.tsx +3 -0
  418. package/src/components/ScreenStackHeaderConfig.tsx +76 -0
  419. package/src/components/ScreenStackHeaderConfig.web.tsx +39 -0
  420. package/src/components/SearchBar.tsx +91 -0
  421. package/src/components/SearchBar.web.tsx +6 -0
  422. package/src/components/helpers/DelayedFreeze.tsx +27 -0
  423. package/src/core.ts +43 -0
  424. package/src/fabric/ModalScreenNativeComponent.ts +104 -0
  425. package/src/fabric/NativeScreensModule.ts +7 -0
  426. package/src/fabric/NativeScreensModule.web.ts +1 -0
  427. package/src/fabric/ScreenNativeComponent.ts +1 -1
  428. package/src/fabric/SearchBarNativeComponent.ts +2 -0
  429. package/src/gesture-handler/GestureDetectorProvider.tsx +16 -0
  430. package/src/gesture-handler/RNScreensTurboModule.ts +13 -0
  431. package/src/gesture-handler/ScreenGestureDetector.tsx +241 -0
  432. package/src/gesture-handler/constraints.ts +87 -0
  433. package/src/gesture-handler/defaults.ts +38 -0
  434. package/src/gesture-handler/fabricUtils.ts +39 -0
  435. package/src/gesture-handler/fabricUtils.web.ts +10 -0
  436. package/src/gesture-handler/index.tsx +4 -0
  437. package/src/index.tsx +65 -112
  438. package/src/native-stack/contexts/GHContext.tsx +7 -0
  439. package/src/native-stack/types.tsx +62 -1
  440. package/src/native-stack/views/HeaderConfig.tsx +11 -0
  441. package/src/native-stack/views/NativeStackView.tsx +65 -13
  442. package/src/types.tsx +13 -1
  443. package/lib/commonjs/index.native.js +0 -418
  444. package/lib/commonjs/index.native.js.map +0 -1
  445. package/lib/module/index.native.js +0 -415
  446. package/lib/module/index.native.js.map +0 -1
  447. package/lib/typescript/index.native.d.ts +0 -2
  448. package/src/index.native.tsx +0 -619
@@ -0,0 +1,241 @@
1
+ import React, { useEffect } from 'react';
2
+ import { Dimensions, Platform, findNodeHandle } from 'react-native';
3
+ import {
4
+ GestureDetector,
5
+ Gesture,
6
+ PanGestureHandlerEventPayload,
7
+ GestureUpdateEvent,
8
+ } from 'react-native-gesture-handler';
9
+ import {
10
+ useSharedValue,
11
+ measure,
12
+ startScreenTransition,
13
+ finishScreenTransition,
14
+ makeMutable,
15
+ runOnUI,
16
+ } from 'react-native-reanimated';
17
+ import type { GestureProviderProps } from 'src/native-stack/types';
18
+ import { getShadowNodeWrapperAndTagFromRef, isFabric } from './fabricUtils';
19
+ import { RNScreensTurboModule } from './RNScreensTurboModule';
20
+ import { DefaultEvent, DefaultScreenDimensions } from './defaults';
21
+ import {
22
+ checkBoundaries,
23
+ checkIfTransitionCancelled,
24
+ getAnimationForTransition,
25
+ } from './constraints';
26
+
27
+ const EmptyGestureHandler = Gesture.Fling();
28
+
29
+ const ScreenGestureDetector = ({
30
+ children,
31
+ gestureDetectorBridge,
32
+ goBackGesture,
33
+ screenEdgeGesture,
34
+ transitionAnimation: customTransitionAnimation,
35
+ screensRefs,
36
+ currentRouteKey,
37
+ }: GestureProviderProps) => {
38
+ const sharedEvent = useSharedValue(DefaultEvent);
39
+ const startingGesturePosition = useSharedValue(DefaultEvent);
40
+ const canPerformUpdates = makeMutable(false);
41
+ const transitionAnimation = getAnimationForTransition(
42
+ goBackGesture,
43
+ customTransitionAnimation
44
+ );
45
+ const screenTransitionConfig = makeMutable({
46
+ stackTag: -1,
47
+ belowTopScreenId: -1,
48
+ topScreenId: -1,
49
+ sharedEvent,
50
+ startingGesturePosition,
51
+ screenTransition: transitionAnimation,
52
+ isTransitionCanceled: false,
53
+ goBackGesture: goBackGesture ?? 'swipeRight',
54
+ screenDimensions: DefaultScreenDimensions,
55
+ onFinishAnimation: () => {
56
+ 'worklet';
57
+ },
58
+ });
59
+ const stackTag = makeMutable(-1);
60
+ const screenTagToNodeWrapperUI = makeMutable<Record<string, any>>({});
61
+ const IS_FABRIC = isFabric();
62
+
63
+ gestureDetectorBridge.current.stackUseEffectCallback = stackRef => {
64
+ if (!goBackGesture) {
65
+ return;
66
+ }
67
+ stackTag.value = findNodeHandle(stackRef.current as any) as number;
68
+ if (Platform.OS === 'ios') {
69
+ runOnUI(() => {
70
+ RNScreensTurboModule.disableSwipeBackForTopScreen(stackTag.value);
71
+ })();
72
+ }
73
+ };
74
+
75
+ useEffect(() => {
76
+ if (!IS_FABRIC || !goBackGesture) {
77
+ return;
78
+ }
79
+ const screenTagToNodeWrapper: Record<string, Record<string, unknown>> = {};
80
+ for (const key in screensRefs.current) {
81
+ const screenRef = screensRefs.current[key];
82
+ const screenData = getShadowNodeWrapperAndTagFromRef(screenRef.current);
83
+ if (screenData.tag && screenData.shadowNodeWrapper) {
84
+ screenTagToNodeWrapper[screenData.tag] = screenData.shadowNodeWrapper;
85
+ } else {
86
+ console.warn('[RNScreens] Failed to find tag for screen.');
87
+ }
88
+ }
89
+ screenTagToNodeWrapperUI.value = screenTagToNodeWrapper;
90
+ }, [currentRouteKey]);
91
+
92
+ function computeProgress(
93
+ event: GestureUpdateEvent<PanGestureHandlerEventPayload>
94
+ ) {
95
+ 'worklet';
96
+ let progress = 0;
97
+ const screenDimensions = screenTransitionConfig.value.screenDimensions;
98
+ const startingPosition = startingGesturePosition.value;
99
+ if (goBackGesture === 'swipeRight') {
100
+ progress =
101
+ event.translationX /
102
+ (screenDimensions.width - startingPosition.absoluteX);
103
+ } else if (goBackGesture === 'swipeLeft') {
104
+ progress = (-1 * event.translationX) / startingPosition.absoluteX;
105
+ } else if (goBackGesture === 'swipeDown') {
106
+ progress =
107
+ (-1 * event.translationY) /
108
+ (screenDimensions.height - startingPosition.absoluteY);
109
+ } else if (goBackGesture === 'swipeUp') {
110
+ progress = event.translationY / startingPosition.absoluteY;
111
+ } else if (goBackGesture === 'horizontalSwipe') {
112
+ progress = Math.abs(event.translationX / screenDimensions.width / 2);
113
+ } else if (goBackGesture === 'verticalSwipe') {
114
+ progress = Math.abs(event.translationY / screenDimensions.height / 2);
115
+ } else if (goBackGesture === 'twoDimensionalSwipe') {
116
+ const progressX = Math.abs(
117
+ event.translationX / screenDimensions.width / 2
118
+ );
119
+ const progressY = Math.abs(
120
+ event.translationY / screenDimensions.height / 2
121
+ );
122
+ progress = Math.max(progressX, progressY);
123
+ }
124
+ return progress;
125
+ }
126
+
127
+ function onStart(event: GestureUpdateEvent<PanGestureHandlerEventPayload>) {
128
+ 'worklet';
129
+ sharedEvent.value = event;
130
+ const transitionConfig = screenTransitionConfig.value;
131
+ const transitionData = RNScreensTurboModule.startTransition(stackTag.value);
132
+ if (transitionData.canStartTransition === false) {
133
+ canPerformUpdates.value = false;
134
+ return;
135
+ }
136
+
137
+ if (IS_FABRIC) {
138
+ transitionConfig.topScreenId =
139
+ screenTagToNodeWrapperUI.value[transitionData.topScreenTag];
140
+ transitionConfig.belowTopScreenId =
141
+ screenTagToNodeWrapperUI.value[transitionData.belowTopScreenTag];
142
+ } else {
143
+ transitionConfig.topScreenId = transitionData.topScreenTag;
144
+ transitionConfig.belowTopScreenId = transitionData.belowTopScreenTag;
145
+ }
146
+
147
+ transitionConfig.stackTag = stackTag.value;
148
+ startingGesturePosition.value = event;
149
+ const animatedRefMock = () => {
150
+ return screenTransitionConfig.value.topScreenId;
151
+ };
152
+ const screenSize = measure(animatedRefMock as any);
153
+ if (screenSize == null) {
154
+ throw new Error('[RNScreens] Failed to measure screen.');
155
+ }
156
+ if (screenSize == null) {
157
+ canPerformUpdates.value = false;
158
+ RNScreensTurboModule.finishTransition(stackTag.value, true);
159
+ return;
160
+ }
161
+ transitionConfig.screenDimensions = screenSize;
162
+ startScreenTransition(transitionConfig);
163
+ canPerformUpdates.value = true;
164
+ }
165
+
166
+ function onUpdate(event: GestureUpdateEvent<PanGestureHandlerEventPayload>) {
167
+ 'worklet';
168
+ if (!canPerformUpdates.value) {
169
+ return;
170
+ }
171
+ checkBoundaries(goBackGesture, event);
172
+ const progress = computeProgress(event);
173
+ sharedEvent.value = event;
174
+ const stackTag = screenTransitionConfig.value.stackTag;
175
+ RNScreensTurboModule.updateTransition(stackTag, progress);
176
+ }
177
+
178
+ function onEnd(event: GestureUpdateEvent<PanGestureHandlerEventPayload>) {
179
+ 'worklet';
180
+ if (!canPerformUpdates.value) {
181
+ return;
182
+ }
183
+
184
+ const velocityFactor = 0.3;
185
+ const screenSize = screenTransitionConfig.value.screenDimensions;
186
+ const distanceX =
187
+ event.translationX + Math.min(event.velocityX * velocityFactor, 100);
188
+ const distanceY =
189
+ event.translationY + Math.min(event.velocityY * velocityFactor, 100);
190
+ const requiredXDistance = screenSize.width / 2;
191
+ const requiredYDistance = screenSize.height / 2;
192
+ const isTransitionCanceled = checkIfTransitionCancelled(
193
+ goBackGesture,
194
+ distanceX,
195
+ requiredXDistance,
196
+ distanceY,
197
+ requiredYDistance
198
+ );
199
+ const stackTag = screenTransitionConfig.value.stackTag;
200
+ screenTransitionConfig.value.onFinishAnimation = () => {
201
+ RNScreensTurboModule.finishTransition(stackTag, isTransitionCanceled);
202
+ };
203
+ screenTransitionConfig.value.isTransitionCanceled = isTransitionCanceled;
204
+ finishScreenTransition(screenTransitionConfig.value);
205
+ }
206
+
207
+ let panGesture = Gesture.Pan()
208
+ .onStart(onStart)
209
+ .onUpdate(onUpdate)
210
+ .onEnd(onEnd);
211
+
212
+ if (screenEdgeGesture) {
213
+ const HIT_SLOP_SIZE = 50;
214
+ const ACTIVATION_DISTANCE = 30;
215
+ if (goBackGesture === 'swipeRight') {
216
+ panGesture = panGesture
217
+ .activeOffsetX(ACTIVATION_DISTANCE)
218
+ .hitSlop({ left: 0, top: 0, width: HIT_SLOP_SIZE });
219
+ } else if (goBackGesture === 'swipeLeft') {
220
+ panGesture = panGesture
221
+ .activeOffsetX(-ACTIVATION_DISTANCE)
222
+ .hitSlop({ right: 0, top: 0, width: HIT_SLOP_SIZE });
223
+ } else if (goBackGesture === 'swipeDown') {
224
+ panGesture = panGesture
225
+ .activeOffsetY(ACTIVATION_DISTANCE)
226
+ .hitSlop({ top: 0, height: Dimensions.get('window').height * 0.2 });
227
+ // workaround, because we don't have access to header height
228
+ } else if (goBackGesture === 'swipeUp') {
229
+ panGesture = panGesture
230
+ .activeOffsetY(-ACTIVATION_DISTANCE)
231
+ .hitSlop({ bottom: 0, height: HIT_SLOP_SIZE });
232
+ }
233
+ }
234
+ return (
235
+ <GestureDetector gesture={goBackGesture ? panGesture : EmptyGestureHandler}>
236
+ {children}
237
+ </GestureDetector>
238
+ );
239
+ };
240
+
241
+ export default ScreenGestureDetector;
@@ -0,0 +1,87 @@
1
+ import { ScreenTransition } from 'react-native-reanimated';
2
+ import {
3
+ AnimatedScreenTransition,
4
+ GoBackGesture,
5
+ PanGestureHandlerEventPayload,
6
+ } from '../native-stack/types';
7
+ import { AnimationForGesture } from './defaults';
8
+ import { GestureUpdateEvent } from 'react-native-gesture-handler';
9
+
10
+ const SupportedGestures = [
11
+ 'swipeRight',
12
+ 'swipeLeft',
13
+ 'swipeDown',
14
+ 'swipeUp',
15
+ 'horizontalSwipe',
16
+ 'verticalSwipe',
17
+ 'twoDimensionalSwipe',
18
+ ];
19
+
20
+ export function getAnimationForTransition(
21
+ goBackGesture: GoBackGesture | undefined,
22
+ customTransitionAnimation: AnimatedScreenTransition | undefined
23
+ ) {
24
+ let transitionAnimation = ScreenTransition.SwipeRight;
25
+ if (customTransitionAnimation) {
26
+ transitionAnimation = customTransitionAnimation;
27
+ if (!goBackGesture) {
28
+ throw new Error(
29
+ '[RNScreens] You have to specify `goBackGesture` when using `transitionAnimation`.'
30
+ );
31
+ }
32
+ } else {
33
+ if (!!goBackGesture && SupportedGestures.includes(goBackGesture)) {
34
+ transitionAnimation = AnimationForGesture[goBackGesture];
35
+ } else if (goBackGesture !== undefined) {
36
+ throw new Error(
37
+ `[RNScreens] Unknown goBackGesture parameter has been specified: ${goBackGesture}.`
38
+ );
39
+ }
40
+ }
41
+ return transitionAnimation;
42
+ }
43
+
44
+ export function checkBoundaries(
45
+ goBackGesture: string | undefined,
46
+ event: GestureUpdateEvent<PanGestureHandlerEventPayload>
47
+ ) {
48
+ 'worklet';
49
+ if (goBackGesture === 'swipeRight' && event.translationX < 0) {
50
+ event.translationX = 0;
51
+ } else if (goBackGesture === 'swipeLeft' && event.translationX > 0) {
52
+ event.translationX = 0;
53
+ } else if (goBackGesture === 'swipeDown' && event.translationY < 0) {
54
+ event.translationY = 0;
55
+ } else if (goBackGesture === 'swipeUp' && event.translationY > 0) {
56
+ event.translationY = 0;
57
+ }
58
+ }
59
+
60
+ export function checkIfTransitionCancelled(
61
+ goBackGesture: string | undefined,
62
+ distanceX: number,
63
+ requiredXDistance: number,
64
+ distanceY: number,
65
+ requiredYDistance: number
66
+ ) {
67
+ 'worklet';
68
+ let isTransitionCanceled = false;
69
+ if (goBackGesture === 'swipeRight') {
70
+ isTransitionCanceled = distanceX < requiredXDistance;
71
+ } else if (goBackGesture === 'swipeLeft') {
72
+ isTransitionCanceled = -distanceX < requiredXDistance;
73
+ } else if (goBackGesture === 'horizontalSwipe') {
74
+ isTransitionCanceled = Math.abs(distanceX) < requiredXDistance;
75
+ } else if (goBackGesture === 'swipeUp') {
76
+ isTransitionCanceled = -distanceY < requiredYDistance;
77
+ } else if (goBackGesture === 'swipeDown') {
78
+ isTransitionCanceled = distanceY < requiredYDistance;
79
+ } else if (goBackGesture === 'verticalSwipe') {
80
+ isTransitionCanceled = Math.abs(distanceY) < requiredYDistance;
81
+ } else if (goBackGesture === 'twoDimensionalSwipe') {
82
+ const isCanceledHorizontally = Math.abs(distanceX) < requiredXDistance;
83
+ const isCanceledVertically = Math.abs(distanceY) < requiredYDistance;
84
+ isTransitionCanceled = isCanceledHorizontally && isCanceledVertically;
85
+ }
86
+ return isTransitionCanceled;
87
+ }
@@ -0,0 +1,38 @@
1
+ import {
2
+ GestureUpdateEvent,
3
+ PanGestureHandlerEventPayload,
4
+ } from 'react-native-gesture-handler';
5
+ import { ScreenTransition } from 'react-native-reanimated';
6
+
7
+ export const DefaultEvent: GestureUpdateEvent<PanGestureHandlerEventPayload> = {
8
+ absoluteX: 0,
9
+ absoluteY: 0,
10
+ handlerTag: 0,
11
+ numberOfPointers: 0,
12
+ state: 0,
13
+ translationX: 0,
14
+ translationY: 0,
15
+ velocityX: 0,
16
+ velocityY: 0,
17
+ x: 0,
18
+ y: 0,
19
+ };
20
+
21
+ export const DefaultScreenDimensions = {
22
+ width: 0,
23
+ height: 0,
24
+ x: 0,
25
+ y: 0,
26
+ pageX: 0,
27
+ pageY: 0,
28
+ };
29
+
30
+ export const AnimationForGesture = {
31
+ swipeRight: ScreenTransition.SwipeRight,
32
+ swipeLeft: ScreenTransition.SwipeLeft,
33
+ swipeDown: ScreenTransition.SwipeDown,
34
+ swipeUp: ScreenTransition.SwipeUp,
35
+ horizontalSwipe: ScreenTransition.Horizontal,
36
+ verticalSwipe: ScreenTransition.Vertical,
37
+ twoDimensionalSwipe: ScreenTransition.TwoDimensional,
38
+ };
@@ -0,0 +1,39 @@
1
+ import { NativeStackNavigatorProps } from '../native-stack/types';
2
+
3
+ interface HostInstance {
4
+ _internalInstanceHandle: {
5
+ stateNode: {
6
+ node: Record<string, unknown>;
7
+ };
8
+ };
9
+ _nativeTag: number;
10
+ }
11
+
12
+ type LocalGlobal = typeof global & Record<string, unknown>;
13
+
14
+ export function isFabric() {
15
+ return !!(global as LocalGlobal)._IS_FABRIC;
16
+ }
17
+
18
+ let findHostInstance: (ref: React.Component) => HostInstance | null = () => {
19
+ return null;
20
+ };
21
+ if (isFabric()) {
22
+ try {
23
+ findHostInstance =
24
+ // eslint-disable-next-line @typescript-eslint/no-var-requires
25
+ require('react-native/Libraries/Renderer/shims/ReactFabric').findHostInstance_DEPRECATED;
26
+ } catch (e) {
27
+ throw new Error('[RNScreens] Cannot import `findHostInstance_DEPRECATED`.');
28
+ }
29
+ }
30
+
31
+ export function getShadowNodeWrapperAndTagFromRef(
32
+ ref: React.Ref<NativeStackNavigatorProps> | React.Component
33
+ ) {
34
+ const hostInstance = findHostInstance(ref as React.Component);
35
+ return {
36
+ shadowNodeWrapper: hostInstance?._internalInstanceHandle.stateNode.node,
37
+ tag: hostInstance?._nativeTag,
38
+ };
39
+ }
@@ -0,0 +1,10 @@
1
+ export function isFabric() {
2
+ return false;
3
+ }
4
+
5
+ export function getShadowNodeWrapperAndTagFromRef() {
6
+ return {
7
+ shadowNodeWrapper: undefined,
8
+ tag: undefined,
9
+ };
10
+ }
@@ -0,0 +1,4 @@
1
+ /*
2
+ * Providers
3
+ */
4
+ export { default as GestureDetectorProvider } from './GestureDetectorProvider';
package/src/index.tsx CHANGED
@@ -1,119 +1,72 @@
1
- import React, { ReactNode } from 'react';
2
- import { Animated, View, ViewProps, ImageProps, Image } from 'react-native';
3
- import {
4
- ScreenProps,
5
- ScreenContainerProps,
6
- ScreenStackProps,
7
- ScreenStackHeaderConfigProps,
8
- HeaderSubviewTypes,
9
- SearchBarProps,
10
- } from './types';
11
-
12
1
  export * from './types';
13
- export { default as useTransitionProgress } from './useTransitionProgress';
14
- export {
15
- isSearchBarAvailableForCurrentPlatform,
16
- isNewBackTitleImplementation,
17
- executeNativeBackPress,
18
- } from './utils';
19
-
20
- let ENABLE_SCREENS = true;
21
-
22
- export function enableScreens(shouldEnableScreens = true): void {
23
- ENABLE_SCREENS = shouldEnableScreens;
24
- }
25
-
26
- export function screensEnabled(): boolean {
27
- return ENABLE_SCREENS;
28
- }
29
-
30
- // @ts-ignore function stub, freezing logic is located in index.native.tsx
31
- // eslint-disable-next-line @typescript-eslint/no-unused-vars
32
- export function enableFreeze(shouldEnableReactFreeze = true): void {
33
- // noop
34
- }
35
-
36
- export class NativeScreen extends React.Component<ScreenProps> {
37
- render(): JSX.Element {
38
- let {
39
- active,
40
- activityState,
41
- style,
42
- enabled = ENABLE_SCREENS,
43
- ...rest
44
- } = this.props;
45
-
46
- if (enabled) {
47
- if (active !== undefined && activityState === undefined) {
48
- activityState = active !== 0 ? 2 : 0; // change taken from index.native.tsx
49
- }
50
- return (
51
- <View
52
- // @ts-expect-error: hidden exists on web, but not in React Native
53
- hidden={activityState === 0}
54
- style={[style, { display: activityState !== 0 ? 'flex' : 'none' }]}
55
- {...rest}
56
- />
57
- );
58
- }
59
-
60
- return <View {...rest} />;
61
- }
62
- }
63
-
64
- export const Screen = Animated.createAnimatedComponent(NativeScreen);
65
-
66
- export const InnerScreen = View;
67
-
68
- export const ScreenContext = React.createContext(Screen);
69
-
70
- export const ScreenContainer: React.ComponentType<ScreenContainerProps> = View;
71
2
 
72
- export const NativeScreenContainer: React.ComponentType<ScreenContainerProps> =
73
- View;
74
-
75
- export const NativeScreenNavigationContainer: React.ComponentType<ScreenContainerProps> =
76
- View;
77
-
78
- export const ScreenStack: React.ComponentType<ScreenStackProps> = View;
79
-
80
- export const FullWindowOverlay = View as React.ComponentType<{
81
- children: ReactNode;
82
- }>;
83
-
84
- export const ScreenStackHeaderBackButtonImage = (
85
- props: ImageProps
86
- ): JSX.Element => (
87
- <View>
88
- <Image resizeMode="center" fadeDuration={0} {...props} />
89
- </View>
90
- );
91
-
92
- export const ScreenStackHeaderRightView = (
93
- props: React.PropsWithChildren<ViewProps>
94
- ): JSX.Element => <View {...props} />;
95
-
96
- export const ScreenStackHeaderLeftView = (
97
- props: React.PropsWithChildren<ViewProps>
98
- ): JSX.Element => <View {...props} />;
99
-
100
- export const ScreenStackHeaderCenterView = (
101
- props: React.PropsWithChildren<ViewProps>
102
- ): JSX.Element => <View {...props} />;
3
+ /*
4
+ * Core
5
+ */
6
+ export {
7
+ enableScreens,
8
+ enableFreeze,
9
+ screensEnabled,
10
+ freezeEnabled,
11
+ shouldUseActivityState,
12
+ } from './core';
13
+
14
+ /*
15
+ * RNS Components
16
+ */
17
+ export {
18
+ default as Screen,
19
+ NativeScreen,
20
+ InnerScreen,
21
+ ScreenContext,
22
+ } from './components/Screen';
103
23
 
104
- export const ScreenStackHeaderSearchBarView = (
105
- props: React.PropsWithChildren<Omit<SearchBarProps, 'ref'>>
106
- ): JSX.Element => <View {...props} />;
24
+ export {
25
+ default as ScreenContainer,
26
+ NativeScreenContainer,
27
+ NativeScreenNavigationContainer,
28
+ } from './components/ScreenContainer';
107
29
 
108
- export const ScreenStackHeaderConfig = (
109
- props: React.PropsWithChildren<ScreenStackHeaderConfigProps>
110
- ): JSX.Element => <View {...props} />;
30
+ export { default as ScreenStack } from './components/ScreenStack';
111
31
 
112
- // @ts-expect-error: search bar props have no common props with View
113
- export const SearchBar: React.ComponentType<SearchBarProps> = View;
32
+ export {
33
+ ScreenStackHeaderConfig,
34
+ ScreenStackHeaderSubview,
35
+ ScreenStackHeaderLeftView,
36
+ ScreenStackHeaderCenterView,
37
+ ScreenStackHeaderRightView,
38
+ ScreenStackHeaderBackButtonImage,
39
+ ScreenStackHeaderSearchBarView,
40
+ } from './components/ScreenStackHeaderConfig';
114
41
 
115
- export const ScreenStackHeaderSubview: React.ComponentType<
116
- React.PropsWithChildren<ViewProps & { type?: HeaderSubviewTypes }>
117
- > = View;
42
+ export {
43
+ default as SearchBar,
44
+ NativeSearchBar,
45
+ NativeSearchBarCommands,
46
+ } from './components/SearchBar';
47
+
48
+ export { default as FullWindowOverlay } from './components/FullWindowOverlay';
49
+
50
+ /*
51
+ * Modules
52
+ */
53
+ export { default as NativeScreensModule } from './fabric/NativeScreensModule';
54
+
55
+ /*
56
+ * Contexts
57
+ */
58
+ export { GHContext } from './native-stack/contexts/GHContext';
59
+
60
+ /*
61
+ * Utils
62
+ */
63
+ export {
64
+ isSearchBarAvailableForCurrentPlatform,
65
+ isNewBackTitleImplementation,
66
+ executeNativeBackPress,
67
+ } from './utils';
118
68
 
119
- export const shouldUseActivityState = true;
69
+ /*
70
+ * Hooks
71
+ */
72
+ export { default as useTransitionProgress } from './useTransitionProgress';
@@ -0,0 +1,7 @@
1
+ import React, { PropsWithChildren } from 'react';
2
+ import { GestureProviderProps } from '../types';
3
+
4
+ // context to be used when the user wants full screen swipe (see `gesture-handler` folder in repo)
5
+ export const GHContext = React.createContext(
6
+ (props: PropsWithChildren<GestureProviderProps>) => <>{props.children}</>
7
+ );