react-native-screen-transitions 3.0.0-beta.8 → 3.0.0-rc.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 (417) hide show
  1. package/README.md +60 -5
  2. package/lib/commonjs/blank-stack/components/Overlay.js +7 -4
  3. package/lib/commonjs/blank-stack/components/Overlay.js.map +1 -1
  4. package/lib/commonjs/blank-stack/components/Screens.js +2 -2
  5. package/lib/commonjs/blank-stack/components/Screens.js.map +1 -1
  6. package/lib/commonjs/blank-stack/components/StackView.js +9 -5
  7. package/lib/commonjs/blank-stack/components/StackView.js.map +1 -1
  8. package/lib/commonjs/blank-stack/hooks/use-overlay-animation.js +5 -9
  9. package/lib/commonjs/blank-stack/hooks/use-overlay-animation.js.map +1 -1
  10. package/lib/commonjs/blank-stack/index.js +7 -0
  11. package/lib/commonjs/blank-stack/index.js.map +1 -1
  12. package/lib/commonjs/native-stack/views/NativeStackView.native.js +4 -3
  13. package/lib/commonjs/native-stack/views/NativeStackView.native.js.map +1 -1
  14. package/lib/commonjs/shared/components/controllers/screen-lifecycle.js +9 -9
  15. package/lib/commonjs/shared/components/controllers/screen-lifecycle.js.map +1 -1
  16. package/lib/commonjs/shared/components/create-transition-aware-component.js +11 -14
  17. package/lib/commonjs/shared/components/create-transition-aware-component.js.map +1 -1
  18. package/lib/commonjs/shared/components/root-transition-aware.js +1 -1
  19. package/lib/commonjs/shared/components/root-transition-aware.js.map +1 -1
  20. package/lib/commonjs/shared/configs/presets.js +20 -9
  21. package/lib/commonjs/shared/configs/presets.js.map +1 -1
  22. package/lib/commonjs/shared/constants.js +0 -1
  23. package/lib/commonjs/shared/constants.js.map +1 -1
  24. package/lib/commonjs/shared/hooks/animation/use-associated-style.js +9 -10
  25. package/lib/commonjs/shared/hooks/animation/use-associated-style.js.map +1 -1
  26. package/lib/commonjs/shared/hooks/animation/use-screen-animation.js +10 -25
  27. package/lib/commonjs/shared/hooks/animation/use-screen-animation.js.map +1 -1
  28. package/lib/commonjs/shared/hooks/gestures/use-build-gestures.js +11 -11
  29. package/lib/commonjs/shared/hooks/gestures/use-build-gestures.js.map +1 -1
  30. package/lib/commonjs/shared/hooks/gestures/use-parent-gesture-registry.js +2 -4
  31. package/lib/commonjs/shared/hooks/gestures/use-parent-gesture-registry.js.map +1 -1
  32. package/lib/commonjs/shared/hooks/gestures/use-scroll-registry.js +1 -1
  33. package/lib/commonjs/shared/hooks/reanimated/use-shared-value-state.js.map +1 -0
  34. package/lib/commonjs/shared/hooks/use-stable-callback-value.js.map +1 -1
  35. package/lib/commonjs/shared/hooks/use-stable-callback.js.map +1 -1
  36. package/lib/commonjs/shared/providers/{gestures.js → gestures.provider.js} +1 -1
  37. package/lib/commonjs/shared/providers/gestures.provider.js.map +1 -0
  38. package/lib/commonjs/shared/providers/{keys.js → keys.provider.js} +1 -1
  39. package/lib/commonjs/shared/providers/keys.provider.js.map +1 -0
  40. package/lib/commonjs/shared/providers/register-bounds.provider.js +211 -0
  41. package/lib/commonjs/shared/providers/register-bounds.provider.js.map +1 -0
  42. package/lib/commonjs/shared/providers/{screen-transition-provider.js → screen-transition.provider.js} +4 -4
  43. package/lib/commonjs/shared/providers/{screen-transition-provider.js.map → screen-transition.provider.js.map} +1 -1
  44. package/lib/commonjs/shared/providers/{transition-styles.js → transition-styles.provider.js} +9 -9
  45. package/lib/commonjs/shared/providers/transition-styles.provider.js.map +1 -0
  46. package/lib/commonjs/shared/stores/{animation-store.js → animation.store.js} +1 -1
  47. package/lib/commonjs/shared/stores/{animation-store.js.map → animation.store.js.map} +1 -1
  48. package/lib/commonjs/shared/stores/bounds.store.js +141 -0
  49. package/lib/commonjs/shared/stores/bounds.store.js.map +1 -0
  50. package/lib/commonjs/shared/stores/{gesture-store.js → gesture.store.js} +1 -1
  51. package/lib/commonjs/shared/stores/{gesture-store.js.map → gesture.store.js.map} +1 -1
  52. package/lib/commonjs/shared/types/{core.js → animation.types.js} +1 -1
  53. package/lib/commonjs/shared/types/animation.types.js.map +1 -0
  54. package/lib/commonjs/shared/types/{bounds.js → bounds.types.js} +1 -1
  55. package/lib/commonjs/shared/types/bounds.types.js.map +1 -0
  56. package/lib/commonjs/shared/types/{animation.js → core.types.js} +1 -1
  57. package/lib/commonjs/shared/types/{animation.js.map → core.types.js.map} +1 -1
  58. package/lib/commonjs/shared/types/{gesture.js → gesture.types.js} +1 -1
  59. package/lib/commonjs/shared/types/gesture.types.js.map +1 -0
  60. package/lib/commonjs/shared/types/utils.types.js +2 -0
  61. package/lib/commonjs/shared/types/{core.js.map → utils.types.js.map} +1 -1
  62. package/lib/commonjs/shared/utils/animation/derivations.js +1 -7
  63. package/lib/commonjs/shared/utils/animation/derivations.js.map +1 -1
  64. package/lib/commonjs/shared/utils/bounds/helpers/geometry.js.map +1 -0
  65. package/lib/commonjs/shared/utils/bounds/helpers/is-bounds-equal.js +19 -0
  66. package/lib/commonjs/shared/utils/bounds/helpers/is-bounds-equal.js.map +1 -0
  67. package/lib/commonjs/shared/utils/bounds/helpers/style-composers.js.map +1 -0
  68. package/lib/commonjs/shared/utils/bounds/helpers/styles.js.map +1 -0
  69. package/lib/commonjs/shared/utils/bounds/index.js +45 -35
  70. package/lib/commonjs/shared/utils/bounds/index.js.map +1 -1
  71. package/lib/commonjs/shared/utils/bounds/types/builder.js.map +1 -0
  72. package/lib/commonjs/shared/utils/bounds/{_types/builder.js.map → types/geometry.js.map} +1 -1
  73. package/lib/commonjs/shared/utils/create-provider.js.map +1 -0
  74. package/lib/commonjs/shared/utils/gesture/apply-offset-rules.js +1 -1
  75. package/lib/commonjs/shared/utils/gesture/check-gesture-activation.js +1 -1
  76. package/lib/commonjs/shared/utils/reset-stores-for-screen.js +17 -0
  77. package/lib/commonjs/shared/utils/reset-stores-for-screen.js.map +1 -0
  78. package/lib/module/blank-stack/components/Overlay.js +7 -4
  79. package/lib/module/blank-stack/components/Overlay.js.map +1 -1
  80. package/lib/module/blank-stack/components/Screens.js +1 -1
  81. package/lib/module/blank-stack/components/StackView.js +8 -4
  82. package/lib/module/blank-stack/components/StackView.js.map +1 -1
  83. package/lib/module/blank-stack/hooks/use-overlay-animation.js +5 -9
  84. package/lib/module/blank-stack/hooks/use-overlay-animation.js.map +1 -1
  85. package/lib/module/blank-stack/index.js +1 -0
  86. package/lib/module/blank-stack/index.js.map +1 -1
  87. package/lib/module/native-stack/views/NativeStackView.native.js +3 -2
  88. package/lib/module/native-stack/views/NativeStackView.native.js.map +1 -1
  89. package/lib/module/shared/components/controllers/screen-lifecycle.js +8 -8
  90. package/lib/module/shared/components/controllers/screen-lifecycle.js.map +1 -1
  91. package/lib/module/shared/components/create-transition-aware-component.js +11 -14
  92. package/lib/module/shared/components/create-transition-aware-component.js.map +1 -1
  93. package/lib/module/shared/components/root-transition-aware.js +1 -1
  94. package/lib/module/shared/components/root-transition-aware.js.map +1 -1
  95. package/lib/module/shared/configs/presets.js +20 -9
  96. package/lib/module/shared/configs/presets.js.map +1 -1
  97. package/lib/module/shared/constants.js +0 -1
  98. package/lib/module/shared/constants.js.map +1 -1
  99. package/lib/module/shared/hooks/animation/use-associated-style.js +9 -10
  100. package/lib/module/shared/hooks/animation/use-associated-style.js.map +1 -1
  101. package/lib/module/shared/hooks/animation/use-screen-animation.js +7 -22
  102. package/lib/module/shared/hooks/animation/use-screen-animation.js.map +1 -1
  103. package/lib/module/shared/hooks/gestures/use-build-gestures.js +4 -4
  104. package/lib/module/shared/hooks/gestures/use-build-gestures.js.map +1 -1
  105. package/lib/module/shared/hooks/gestures/use-parent-gesture-registry.js +2 -4
  106. package/lib/module/shared/hooks/gestures/use-parent-gesture-registry.js.map +1 -1
  107. package/lib/module/shared/hooks/gestures/use-scroll-registry.js +1 -1
  108. package/lib/module/shared/hooks/gestures/use-scroll-registry.js.map +1 -1
  109. package/lib/module/shared/hooks/reanimated/use-shared-value-state.js.map +1 -0
  110. package/lib/module/shared/hooks/use-stable-callback-value.js.map +1 -1
  111. package/lib/module/shared/hooks/use-stable-callback.js.map +1 -1
  112. package/lib/module/shared/providers/{gestures.js → gestures.provider.js} +1 -1
  113. package/lib/module/shared/providers/gestures.provider.js.map +1 -0
  114. package/lib/module/shared/providers/{keys.js → keys.provider.js} +1 -1
  115. package/lib/module/shared/providers/keys.provider.js.map +1 -0
  116. package/lib/module/shared/providers/register-bounds.provider.js +206 -0
  117. package/lib/module/shared/providers/register-bounds.provider.js.map +1 -0
  118. package/lib/module/shared/providers/{screen-transition-provider.js → screen-transition.provider.js} +4 -4
  119. package/lib/module/shared/providers/{screen-transition-provider.js.map → screen-transition.provider.js.map} +1 -1
  120. package/lib/module/shared/providers/{transition-styles.js → transition-styles.provider.js} +8 -9
  121. package/lib/module/shared/providers/transition-styles.provider.js.map +1 -0
  122. package/lib/module/shared/stores/{animation-store.js → animation.store.js} +1 -1
  123. package/lib/module/shared/stores/{animation-store.js.map → animation.store.js.map} +1 -1
  124. package/lib/module/shared/stores/bounds.store.js +137 -0
  125. package/lib/module/shared/stores/bounds.store.js.map +1 -0
  126. package/lib/module/shared/stores/{gesture-store.js → gesture.store.js} +1 -1
  127. package/lib/module/shared/stores/{gesture-store.js.map → gesture.store.js.map} +1 -1
  128. package/lib/module/shared/types/animation.types.js +4 -0
  129. package/lib/module/shared/types/animation.types.js.map +1 -0
  130. package/lib/module/shared/types/bounds.types.js +4 -0
  131. package/lib/module/shared/types/bounds.types.js.map +1 -0
  132. package/lib/module/shared/types/core.types.js +4 -0
  133. package/lib/{commonjs/shared/types/bounds.js.map → module/shared/types/core.types.js.map} +1 -1
  134. package/lib/module/shared/types/{gesture.js → gesture.types.js} +1 -1
  135. package/lib/module/shared/types/gesture.types.js.map +1 -0
  136. package/lib/module/shared/types/utils.types.js +2 -0
  137. package/lib/{commonjs/shared/types/utils.js.map → module/shared/types/utils.types.js.map} +1 -1
  138. package/lib/module/shared/utils/animation/derivations.js +1 -7
  139. package/lib/module/shared/utils/animation/derivations.js.map +1 -1
  140. package/lib/module/shared/utils/bounds/helpers/geometry.js.map +1 -0
  141. package/lib/module/shared/utils/bounds/helpers/is-bounds-equal.js +14 -0
  142. package/lib/module/shared/utils/bounds/helpers/is-bounds-equal.js.map +1 -0
  143. package/lib/module/shared/utils/bounds/helpers/style-composers.js.map +1 -0
  144. package/lib/module/shared/utils/bounds/helpers/styles.js.map +1 -0
  145. package/lib/module/shared/utils/bounds/index.js +45 -35
  146. package/lib/module/shared/utils/bounds/index.js.map +1 -1
  147. package/lib/module/shared/utils/bounds/types/builder.js.map +1 -0
  148. package/lib/module/shared/utils/bounds/{_types/builder.js.map → types/geometry.js.map} +1 -1
  149. package/lib/module/shared/utils/create-provider.js.map +1 -0
  150. package/lib/module/shared/utils/gesture/apply-offset-rules.js +1 -1
  151. package/lib/module/shared/utils/gesture/apply-offset-rules.js.map +1 -1
  152. package/lib/module/shared/utils/gesture/check-gesture-activation.js +1 -1
  153. package/lib/module/shared/utils/gesture/check-gesture-activation.js.map +1 -1
  154. package/lib/module/shared/utils/reset-stores-for-screen.js +13 -0
  155. package/lib/module/shared/utils/reset-stores-for-screen.js.map +1 -0
  156. package/lib/typescript/blank-stack/components/Overlay.d.ts.map +1 -1
  157. package/lib/typescript/blank-stack/components/StackView.d.ts.map +1 -1
  158. package/lib/typescript/blank-stack/hooks/use-overlay-animation.d.ts +1 -1
  159. package/lib/typescript/blank-stack/hooks/use-overlay-animation.d.ts.map +1 -1
  160. package/lib/typescript/blank-stack/index.d.ts +1 -0
  161. package/lib/typescript/blank-stack/index.d.ts.map +1 -1
  162. package/lib/typescript/blank-stack/types.d.ts +2 -2
  163. package/lib/typescript/blank-stack/types.d.ts.map +1 -1
  164. package/lib/typescript/native-stack/types.d.ts +1 -1
  165. package/lib/typescript/native-stack/types.d.ts.map +1 -1
  166. package/lib/typescript/native-stack/views/NativeStackView.native.d.ts.map +1 -1
  167. package/lib/typescript/shared/components/controllers/screen-lifecycle.d.ts.map +1 -1
  168. package/lib/typescript/shared/components/create-transition-aware-component.d.ts.map +1 -1
  169. package/lib/typescript/shared/configs/index.d.ts +9 -3
  170. package/lib/typescript/shared/configs/index.d.ts.map +1 -1
  171. package/lib/typescript/shared/configs/presets.d.ts +10 -4
  172. package/lib/typescript/shared/configs/presets.d.ts.map +1 -1
  173. package/lib/typescript/shared/constants.d.ts +6 -6
  174. package/lib/typescript/shared/constants.d.ts.map +1 -1
  175. package/lib/typescript/shared/hooks/animation/use-associated-style.d.ts.map +1 -1
  176. package/lib/typescript/shared/hooks/animation/use-screen-animation.d.ts +2 -2
  177. package/lib/typescript/shared/hooks/animation/use-screen-animation.d.ts.map +1 -1
  178. package/lib/typescript/shared/hooks/gestures/use-build-gestures.d.ts +2 -2
  179. package/lib/typescript/shared/hooks/gestures/use-build-gestures.d.ts.map +1 -1
  180. package/lib/typescript/shared/hooks/gestures/use-parent-gesture-registry.d.ts.map +1 -1
  181. package/lib/typescript/shared/hooks/reanimated/use-shared-value-state.d.ts.map +1 -0
  182. package/lib/typescript/shared/hooks/use-stable-callback-value.d.ts.map +1 -1
  183. package/lib/typescript/shared/hooks/use-stable-callback.d.ts.map +1 -1
  184. package/lib/typescript/shared/index.d.ts +25 -19
  185. package/lib/typescript/shared/index.d.ts.map +1 -1
  186. package/lib/typescript/shared/providers/{gestures.d.ts → gestures.provider.d.ts} +2 -2
  187. package/lib/typescript/shared/providers/gestures.provider.d.ts.map +1 -0
  188. package/lib/typescript/shared/providers/{keys.d.ts → keys.provider.d.ts} +2 -2
  189. package/lib/typescript/shared/providers/keys.provider.d.ts.map +1 -0
  190. package/lib/typescript/shared/providers/register-bounds.provider.d.ts +17 -0
  191. package/lib/typescript/shared/providers/register-bounds.provider.d.ts.map +1 -0
  192. package/lib/typescript/shared/providers/{screen-transition-provider.d.ts → screen-transition.provider.d.ts} +2 -2
  193. package/lib/typescript/shared/providers/{screen-transition-provider.d.ts.map → screen-transition.provider.d.ts.map} +1 -1
  194. package/lib/typescript/shared/providers/transition-styles.provider.d.ts +14 -0
  195. package/lib/typescript/shared/providers/transition-styles.provider.d.ts.map +1 -0
  196. package/lib/typescript/shared/stores/{animation-store.d.ts → animation.store.d.ts} +2 -2
  197. package/lib/typescript/shared/stores/animation.store.d.ts.map +1 -0
  198. package/lib/typescript/shared/stores/bounds.store.d.ts +29 -0
  199. package/lib/typescript/shared/stores/bounds.store.d.ts.map +1 -0
  200. package/lib/typescript/shared/stores/{gesture-store.d.ts → gesture.store.d.ts} +3 -3
  201. package/lib/typescript/shared/stores/gesture.store.d.ts.map +1 -0
  202. package/lib/typescript/shared/types/{animation.d.ts → animation.types.d.ts} +48 -20
  203. package/lib/typescript/shared/types/animation.types.d.ts.map +1 -0
  204. package/lib/typescript/shared/types/{bounds.d.ts → bounds.types.d.ts} +4 -4
  205. package/lib/typescript/shared/types/bounds.types.d.ts.map +1 -0
  206. package/lib/typescript/shared/types/{core.d.ts → core.types.d.ts} +3 -3
  207. package/lib/typescript/shared/types/core.types.d.ts.map +1 -0
  208. package/lib/typescript/shared/types/{gesture.d.ts → gesture.types.d.ts} +1 -1
  209. package/lib/typescript/shared/types/gesture.types.d.ts.map +1 -0
  210. package/lib/typescript/shared/types/{utils.d.ts → utils.types.d.ts} +1 -1
  211. package/lib/typescript/shared/types/utils.types.d.ts.map +1 -0
  212. package/lib/typescript/shared/utils/animation/derivations.d.ts +2 -4
  213. package/lib/typescript/shared/utils/animation/derivations.d.ts.map +1 -1
  214. package/lib/typescript/shared/utils/animation/start-screen-transition.d.ts +2 -2
  215. package/lib/typescript/shared/utils/animation/start-screen-transition.d.ts.map +1 -1
  216. package/lib/typescript/shared/utils/bounds/constants.d.ts +3 -3
  217. package/lib/typescript/shared/utils/bounds/constants.d.ts.map +1 -1
  218. package/lib/typescript/shared/utils/bounds/{_utils → helpers}/geometry.d.ts +3 -3
  219. package/lib/typescript/shared/utils/bounds/helpers/geometry.d.ts.map +1 -0
  220. package/lib/typescript/shared/utils/bounds/helpers/is-bounds-equal.d.ts.map +1 -0
  221. package/lib/typescript/shared/utils/bounds/{_utils → helpers}/style-composers.d.ts +2 -2
  222. package/lib/typescript/shared/utils/bounds/helpers/style-composers.d.ts.map +1 -0
  223. package/lib/typescript/shared/utils/bounds/{_utils → helpers}/styles.d.ts +1 -1
  224. package/lib/typescript/shared/utils/bounds/helpers/styles.d.ts.map +1 -0
  225. package/lib/typescript/shared/utils/bounds/index.d.ts +3 -4
  226. package/lib/typescript/shared/utils/bounds/index.d.ts.map +1 -1
  227. package/lib/typescript/shared/utils/bounds/{_types → types}/builder.d.ts +13 -34
  228. package/lib/typescript/shared/utils/bounds/types/builder.d.ts.map +1 -0
  229. package/lib/typescript/shared/utils/bounds/types/geometry.d.ts.map +1 -0
  230. package/lib/typescript/shared/{providers/utils → utils}/create-provider.d.ts +2 -2
  231. package/lib/typescript/shared/utils/create-provider.d.ts.map +1 -0
  232. package/lib/typescript/shared/utils/gesture/apply-offset-rules.d.ts +2 -2
  233. package/lib/typescript/shared/utils/gesture/apply-offset-rules.d.ts.map +1 -1
  234. package/lib/typescript/shared/utils/gesture/check-gesture-activation.d.ts +2 -2
  235. package/lib/typescript/shared/utils/gesture/check-gesture-activation.d.ts.map +1 -1
  236. package/lib/typescript/shared/utils/gesture/reset-gesture-values.d.ts +2 -2
  237. package/lib/typescript/shared/utils/gesture/reset-gesture-values.d.ts.map +1 -1
  238. package/lib/typescript/shared/utils/gesture/velocity.d.ts +1 -1
  239. package/lib/typescript/shared/utils/reset-stores-for-screen.d.ts +6 -0
  240. package/lib/typescript/shared/utils/reset-stores-for-screen.d.ts.map +1 -0
  241. package/package.json +1 -1
  242. package/src/blank-stack/components/Overlay.tsx +5 -2
  243. package/src/blank-stack/components/Screens.tsx +1 -1
  244. package/src/blank-stack/components/StackView.tsx +7 -2
  245. package/src/blank-stack/hooks/use-overlay-animation.tsx +6 -21
  246. package/src/blank-stack/index.ts +1 -0
  247. package/src/blank-stack/types.ts +2 -2
  248. package/src/native-stack/types.ts +1 -1
  249. package/src/native-stack/views/NativeStackView.native.tsx +4 -2
  250. package/src/shared/components/controllers/screen-lifecycle.tsx +12 -10
  251. package/src/shared/components/create-transition-aware-component.tsx +23 -27
  252. package/src/shared/components/root-transition-aware.tsx +1 -1
  253. package/src/shared/configs/presets.ts +31 -17
  254. package/src/shared/constants.ts +6 -7
  255. package/src/shared/hooks/animation/use-associated-style.tsx +12 -9
  256. package/src/shared/hooks/animation/use-screen-animation.tsx +8 -26
  257. package/src/shared/hooks/gestures/use-build-gestures.tsx +5 -5
  258. package/src/shared/hooks/gestures/use-parent-gesture-registry.tsx +2 -4
  259. package/src/shared/hooks/gestures/use-scroll-registry.tsx +2 -2
  260. package/src/shared/index.ts +2 -2
  261. package/src/shared/providers/{gestures.tsx → gestures.provider.tsx} +1 -1
  262. package/src/shared/providers/{keys.tsx → keys.provider.tsx} +1 -1
  263. package/src/shared/providers/register-bounds.provider.tsx +290 -0
  264. package/src/shared/providers/{screen-transition-provider.tsx → screen-transition.provider.tsx} +3 -3
  265. package/src/shared/providers/{transition-styles.tsx → transition-styles.provider.tsx} +18 -16
  266. package/src/shared/stores/{animation-store.ts → animation.store.ts} +1 -1
  267. package/src/shared/stores/bounds.store.ts +166 -0
  268. package/src/shared/stores/{gesture-store.ts → gesture.store.ts} +2 -2
  269. package/src/shared/types/{animation.ts → animation.types.ts} +60 -19
  270. package/src/shared/types/{bounds.ts → bounds.types.ts} +3 -3
  271. package/src/shared/types/{core.ts → core.types.ts} +10 -2
  272. package/src/shared/utils/animation/derivations.ts +2 -8
  273. package/src/shared/utils/animation/start-screen-transition.ts +2 -2
  274. package/src/shared/utils/bounds/constants.ts +3 -3
  275. package/src/shared/utils/bounds/{_utils → helpers}/geometry.ts +3 -3
  276. package/src/shared/utils/bounds/{_utils → helpers}/is-bounds-equal.ts +3 -3
  277. package/src/shared/utils/bounds/{_utils → helpers}/style-composers.ts +2 -2
  278. package/src/shared/utils/bounds/{_utils → helpers}/styles.ts +1 -1
  279. package/src/shared/utils/bounds/index.ts +53 -55
  280. package/src/shared/utils/bounds/{_types → types}/builder.ts +19 -37
  281. package/src/shared/{providers/utils → utils}/create-provider.tsx +3 -9
  282. package/src/shared/utils/gesture/apply-offset-rules.ts +2 -2
  283. package/src/shared/utils/gesture/check-gesture-activation.ts +2 -2
  284. package/src/shared/utils/gesture/reset-gesture-values.ts +2 -2
  285. package/src/shared/utils/gesture/velocity.ts +1 -1
  286. package/src/shared/utils/reset-stores-for-screen.ts +11 -0
  287. package/lib/commonjs/shared/hooks/bounds/use-bound-registry.js +0 -152
  288. package/lib/commonjs/shared/hooks/bounds/use-bound-registry.js.map +0 -1
  289. package/lib/commonjs/shared/hooks/use-derived-value-state.js +0 -33
  290. package/lib/commonjs/shared/hooks/use-derived-value-state.js.map +0 -1
  291. package/lib/commonjs/shared/hooks/use-shared-value-state.js.map +0 -1
  292. package/lib/commonjs/shared/providers/gestures.js.map +0 -1
  293. package/lib/commonjs/shared/providers/keys.js.map +0 -1
  294. package/lib/commonjs/shared/providers/transition-styles.js.map +0 -1
  295. package/lib/commonjs/shared/providers/utils/create-provider.js.map +0 -1
  296. package/lib/commonjs/shared/stores/bound-store/_utils.js +0 -118
  297. package/lib/commonjs/shared/stores/bound-store/_utils.js.map +0 -1
  298. package/lib/commonjs/shared/stores/bound-store/index.js +0 -127
  299. package/lib/commonjs/shared/stores/bound-store/index.js.map +0 -1
  300. package/lib/commonjs/shared/stores/utils/reset-stores-for-screen.js +0 -19
  301. package/lib/commonjs/shared/stores/utils/reset-stores-for-screen.js.map +0 -1
  302. package/lib/commonjs/shared/types/gesture.js.map +0 -1
  303. package/lib/commonjs/shared/types/utils.js +0 -2
  304. package/lib/commonjs/shared/utils/bounds/_types/geometry.js.map +0 -1
  305. package/lib/commonjs/shared/utils/bounds/_types/get-bounds.js +0 -6
  306. package/lib/commonjs/shared/utils/bounds/_types/get-bounds.js.map +0 -1
  307. package/lib/commonjs/shared/utils/bounds/_utils/flatten-styles.js +0 -27
  308. package/lib/commonjs/shared/utils/bounds/_utils/flatten-styles.js.map +0 -1
  309. package/lib/commonjs/shared/utils/bounds/_utils/geometry.js.map +0 -1
  310. package/lib/commonjs/shared/utils/bounds/_utils/get-bounds.js +0 -49
  311. package/lib/commonjs/shared/utils/bounds/_utils/get-bounds.js.map +0 -1
  312. package/lib/commonjs/shared/utils/bounds/_utils/is-bounds-equal.js +0 -19
  313. package/lib/commonjs/shared/utils/bounds/_utils/is-bounds-equal.js.map +0 -1
  314. package/lib/commonjs/shared/utils/bounds/_utils/style-composers.js.map +0 -1
  315. package/lib/commonjs/shared/utils/bounds/_utils/styles.js.map +0 -1
  316. package/lib/module/shared/hooks/bounds/use-bound-registry.js +0 -146
  317. package/lib/module/shared/hooks/bounds/use-bound-registry.js.map +0 -1
  318. package/lib/module/shared/hooks/use-derived-value-state.js +0 -30
  319. package/lib/module/shared/hooks/use-derived-value-state.js.map +0 -1
  320. package/lib/module/shared/hooks/use-shared-value-state.js.map +0 -1
  321. package/lib/module/shared/providers/gestures.js.map +0 -1
  322. package/lib/module/shared/providers/keys.js.map +0 -1
  323. package/lib/module/shared/providers/transition-styles.js.map +0 -1
  324. package/lib/module/shared/providers/utils/create-provider.js.map +0 -1
  325. package/lib/module/shared/stores/bound-store/_utils.js +0 -113
  326. package/lib/module/shared/stores/bound-store/_utils.js.map +0 -1
  327. package/lib/module/shared/stores/bound-store/index.js +0 -123
  328. package/lib/module/shared/stores/bound-store/index.js.map +0 -1
  329. package/lib/module/shared/stores/utils/reset-stores-for-screen.js +0 -15
  330. package/lib/module/shared/stores/utils/reset-stores-for-screen.js.map +0 -1
  331. package/lib/module/shared/types/animation.js +0 -4
  332. package/lib/module/shared/types/animation.js.map +0 -1
  333. package/lib/module/shared/types/bounds.js +0 -4
  334. package/lib/module/shared/types/bounds.js.map +0 -1
  335. package/lib/module/shared/types/core.js +0 -4
  336. package/lib/module/shared/types/core.js.map +0 -1
  337. package/lib/module/shared/types/gesture.js.map +0 -1
  338. package/lib/module/shared/types/utils.js +0 -2
  339. package/lib/module/shared/types/utils.js.map +0 -1
  340. package/lib/module/shared/utils/bounds/_types/geometry.js.map +0 -1
  341. package/lib/module/shared/utils/bounds/_types/get-bounds.js +0 -4
  342. package/lib/module/shared/utils/bounds/_types/get-bounds.js.map +0 -1
  343. package/lib/module/shared/utils/bounds/_utils/flatten-styles.js +0 -23
  344. package/lib/module/shared/utils/bounds/_utils/flatten-styles.js.map +0 -1
  345. package/lib/module/shared/utils/bounds/_utils/geometry.js.map +0 -1
  346. package/lib/module/shared/utils/bounds/_utils/get-bounds.js +0 -44
  347. package/lib/module/shared/utils/bounds/_utils/get-bounds.js.map +0 -1
  348. package/lib/module/shared/utils/bounds/_utils/is-bounds-equal.js +0 -14
  349. package/lib/module/shared/utils/bounds/_utils/is-bounds-equal.js.map +0 -1
  350. package/lib/module/shared/utils/bounds/_utils/style-composers.js.map +0 -1
  351. package/lib/module/shared/utils/bounds/_utils/styles.js.map +0 -1
  352. package/lib/typescript/shared/hooks/bounds/use-bound-registry.d.ts +0 -17
  353. package/lib/typescript/shared/hooks/bounds/use-bound-registry.d.ts.map +0 -1
  354. package/lib/typescript/shared/hooks/use-derived-value-state.d.ts +0 -9
  355. package/lib/typescript/shared/hooks/use-derived-value-state.d.ts.map +0 -1
  356. package/lib/typescript/shared/hooks/use-shared-value-state.d.ts.map +0 -1
  357. package/lib/typescript/shared/providers/gestures.d.ts.map +0 -1
  358. package/lib/typescript/shared/providers/keys.d.ts.map +0 -1
  359. package/lib/typescript/shared/providers/transition-styles.d.ts +0 -11
  360. package/lib/typescript/shared/providers/transition-styles.d.ts.map +0 -1
  361. package/lib/typescript/shared/providers/utils/create-provider.d.ts.map +0 -1
  362. package/lib/typescript/shared/stores/animation-store.d.ts.map +0 -1
  363. package/lib/typescript/shared/stores/bound-store/_utils.d.ts +0 -24
  364. package/lib/typescript/shared/stores/bound-store/_utils.d.ts.map +0 -1
  365. package/lib/typescript/shared/stores/bound-store/index.d.ts +0 -24
  366. package/lib/typescript/shared/stores/bound-store/index.d.ts.map +0 -1
  367. package/lib/typescript/shared/stores/gesture-store.d.ts.map +0 -1
  368. package/lib/typescript/shared/stores/utils/reset-stores-for-screen.d.ts +0 -6
  369. package/lib/typescript/shared/stores/utils/reset-stores-for-screen.d.ts.map +0 -1
  370. package/lib/typescript/shared/types/animation.d.ts.map +0 -1
  371. package/lib/typescript/shared/types/bounds.d.ts.map +0 -1
  372. package/lib/typescript/shared/types/core.d.ts.map +0 -1
  373. package/lib/typescript/shared/types/gesture.d.ts.map +0 -1
  374. package/lib/typescript/shared/types/utils.d.ts.map +0 -1
  375. package/lib/typescript/shared/utils/bounds/_types/builder.d.ts.map +0 -1
  376. package/lib/typescript/shared/utils/bounds/_types/geometry.d.ts.map +0 -1
  377. package/lib/typescript/shared/utils/bounds/_types/get-bounds.d.ts +0 -10
  378. package/lib/typescript/shared/utils/bounds/_types/get-bounds.d.ts.map +0 -1
  379. package/lib/typescript/shared/utils/bounds/_utils/flatten-styles.d.ts +0 -2
  380. package/lib/typescript/shared/utils/bounds/_utils/flatten-styles.d.ts.map +0 -1
  381. package/lib/typescript/shared/utils/bounds/_utils/geometry.d.ts.map +0 -1
  382. package/lib/typescript/shared/utils/bounds/_utils/get-bounds.d.ts +0 -4
  383. package/lib/typescript/shared/utils/bounds/_utils/get-bounds.d.ts.map +0 -1
  384. package/lib/typescript/shared/utils/bounds/_utils/is-bounds-equal.d.ts.map +0 -1
  385. package/lib/typescript/shared/utils/bounds/_utils/style-composers.d.ts.map +0 -1
  386. package/lib/typescript/shared/utils/bounds/_utils/styles.d.ts.map +0 -1
  387. package/src/shared/hooks/bounds/use-bound-registry.tsx +0 -184
  388. package/src/shared/hooks/use-derived-value-state.ts +0 -41
  389. package/src/shared/stores/bound-store/_utils.ts +0 -161
  390. package/src/shared/stores/bound-store/index.ts +0 -148
  391. package/src/shared/stores/utils/reset-stores-for-screen.ts +0 -13
  392. package/src/shared/utils/bounds/_types/get-bounds.ts +0 -10
  393. package/src/shared/utils/bounds/_utils/flatten-styles.ts +0 -21
  394. package/src/shared/utils/bounds/_utils/get-bounds.ts +0 -54
  395. /package/lib/commonjs/shared/hooks/{use-shared-value-state.js → reanimated/use-shared-value-state.js} +0 -0
  396. /package/lib/commonjs/shared/utils/bounds/{_utils → helpers}/geometry.js +0 -0
  397. /package/lib/commonjs/shared/utils/bounds/{_utils → helpers}/style-composers.js +0 -0
  398. /package/lib/commonjs/shared/utils/bounds/{_utils → helpers}/styles.js +0 -0
  399. /package/lib/commonjs/shared/utils/bounds/{_types → types}/builder.js +0 -0
  400. /package/lib/commonjs/shared/utils/bounds/{_types → types}/geometry.js +0 -0
  401. /package/lib/commonjs/shared/{providers/utils → utils}/create-provider.js +0 -0
  402. /package/lib/module/shared/hooks/{use-shared-value-state.js → reanimated/use-shared-value-state.js} +0 -0
  403. /package/lib/module/shared/utils/bounds/{_utils → helpers}/geometry.js +0 -0
  404. /package/lib/module/shared/utils/bounds/{_utils → helpers}/style-composers.js +0 -0
  405. /package/lib/module/shared/utils/bounds/{_utils → helpers}/styles.js +0 -0
  406. /package/lib/module/shared/utils/bounds/{_types → types}/builder.js +0 -0
  407. /package/lib/module/shared/utils/bounds/{_types → types}/geometry.js +0 -0
  408. /package/lib/module/shared/{providers/utils → utils}/create-provider.js +0 -0
  409. /package/lib/typescript/shared/hooks/{use-shared-value-state.d.ts → reanimated/use-shared-value-state.d.ts} +0 -0
  410. /package/lib/typescript/shared/utils/bounds/{_utils → helpers}/is-bounds-equal.d.ts +0 -0
  411. /package/lib/typescript/shared/utils/bounds/{_types → types}/geometry.d.ts +0 -0
  412. /package/src/shared/hooks/{use-shared-value-state.ts → reanimated/use-shared-value-state.ts} +0 -0
  413. /package/src/shared/hooks/{use-stable-callback-value.tsx → use-stable-callback-value.ts} +0 -0
  414. /package/src/shared/hooks/{use-stable-callback.tsx → use-stable-callback.ts} +0 -0
  415. /package/src/shared/types/{gesture.ts → gesture.types.ts} +0 -0
  416. /package/src/shared/types/{utils.ts → utils.types.ts} +0 -0
  417. /package/src/shared/utils/bounds/{_types → types}/geometry.ts +0 -0
@@ -1,3 +1,4 @@
1
+ export { useOverlayAnimation } from "../blank-stack/hooks/use-overlay-animation";
1
2
  export { createBlankStackNavigator } from "../blank-stack/navigators/createBlankStackNavigator";
2
3
  export type {
3
4
  BlankStackNavigationEventMap,
@@ -19,11 +19,11 @@ import type {
19
19
  ScreenInterpolationProps,
20
20
  ScreenStyleInterpolator,
21
21
  TransitionSpec,
22
- } from "../shared/types/animation";
22
+ } from "../shared/types/animation.types";
23
23
  import type {
24
24
  GestureActivationArea,
25
25
  GestureDirection,
26
- } from "../shared/types/gesture";
26
+ } from "../shared/types/gesture.types";
27
27
 
28
28
  export type BlankStackNavigationEventMap = {
29
29
  /**
@@ -22,7 +22,7 @@ import type {
22
22
  ScreenStackHeaderConfigProps,
23
23
  SearchBarProps,
24
24
  } from "react-native-screens";
25
- import type { ScreenTransitionConfig } from "../shared/types/core";
25
+ import type { ScreenTransitionConfig } from "../shared/types/core.types";
26
26
 
27
27
  export type Layout = {
28
28
  width: number;
@@ -34,7 +34,7 @@ import {
34
34
  ScreenStackItem,
35
35
  } from "react-native-screens";
36
36
  import { NativeStackScreenLifecycleController } from "../../shared/components/controllers/screen-lifecycle";
37
- import { ScreenTransitionProvider } from "../../shared/providers/screen-transition-provider";
37
+ import { ScreenTransitionProvider } from "../../shared/providers/screen-transition.provider";
38
38
  import type {
39
39
  NativeStackDescriptor,
40
40
  NativeStackDescriptorMap,
@@ -513,11 +513,13 @@ export function NativeStackView({
513
513
  return acc;
514
514
  }, {});
515
515
 
516
+ const routes = state.routes.concat(state.preloadedRoutes);
517
+
516
518
  return (
517
519
  <GestureHandlerRootView>
518
520
  <SafeAreaProviderCompat>
519
521
  <ScreenStack style={styles.container}>
520
- {state.routes.concat(state.preloadedRoutes).map((route, index) => {
522
+ {routes.map((route, index) => {
521
523
  const descriptor =
522
524
  descriptors[route.key] ?? preloadedDescriptors[route.key];
523
525
  const isFocused = state.index === index;
@@ -1,16 +1,16 @@
1
1
  import { useEffect, useLayoutEffect } from "react";
2
- import { useAnimatedReaction } from "react-native-reanimated";
2
+ import { useAnimatedReaction, useDerivedValue } from "react-native-reanimated";
3
3
  import type { BlankStackDescriptor } from "../../../blank-stack/types";
4
4
  import { useStackNavigationContext } from "../../../blank-stack/utils/with-stack-navigation";
5
5
  import type { NativeStackDescriptor } from "../../../native-stack/types";
6
6
  import { useParentGestureRegistry } from "../../hooks/gestures/use-parent-gesture-registry";
7
- import { useDerivedValueState } from "../../hooks/use-derived-value-state";
7
+ import { useSharedValueState } from "../../hooks/reanimated/use-shared-value-state";
8
8
  import useStableCallback from "../../hooks/use-stable-callback";
9
- import { useGestureContext } from "../../providers/gestures";
10
- import { useKeys } from "../../providers/keys";
11
- import { AnimationStore } from "../../stores/animation-store";
12
- import { resetStoresForScreen } from "../../stores/utils/reset-stores-for-screen";
9
+ import { useGestureContext } from "../../providers/gestures.provider";
10
+ import { useKeys } from "../../providers/keys.provider";
11
+ import { AnimationStore } from "../../stores/animation.store";
13
12
  import { startScreenTransition } from "../../utils/animation/start-screen-transition";
13
+ import { resetStoresForScreen } from "../../utils/reset-stores-for-screen";
14
14
 
15
15
  export interface ScreenLifecycleProps {
16
16
  children: React.ReactNode;
@@ -25,10 +25,12 @@ export const NativeStackScreenLifecycleController = ({
25
25
  const { current } = useKeys<NativeStackDescriptor>();
26
26
  const { parentContext } = useGestureContext();
27
27
 
28
- const isParentDismissingViaGesture = useDerivedValueState(() => {
29
- "worklet";
30
- return parentContext?.gestureAnimationValues.isDismissing?.value ?? false;
31
- });
28
+ const isParentDismissingViaGesture = useSharedValueState(
29
+ useDerivedValue(() => {
30
+ "worklet";
31
+ return parentContext?.gestureAnimationValues.isDismissing?.value ?? false;
32
+ }),
33
+ );
32
34
 
33
35
  const animations = AnimationStore.getAll(current.route.key);
34
36
 
@@ -4,11 +4,11 @@ import type { View } from "react-native";
4
4
  import { GestureDetector } from "react-native-gesture-handler";
5
5
  import Animated, { runOnUI, useAnimatedRef } from "react-native-reanimated";
6
6
  import { useAssociatedStyles } from "../hooks/animation/use-associated-style";
7
- import { useBoundsRegistry } from "../hooks/bounds/use-bound-registry";
8
7
  import { useScrollRegistry } from "../hooks/gestures/use-scroll-registry";
9
- import { useGestureContext } from "../providers/gestures";
10
- import type { TransitionAwareProps } from "../types/core";
11
- import type { Any } from "../types/utils";
8
+ import { useGestureContext } from "../providers/gestures.provider";
9
+ import { RegisterBoundsProvider } from "../providers/register-bounds.provider";
10
+ import type { TransitionAwareProps } from "../types/core.types";
11
+ import type { Any } from "../types/utils.types";
12
12
 
13
13
  interface CreateTransitionAwareComponentOptions {
14
14
  isScrollable?: boolean;
@@ -61,30 +61,26 @@ export function createTransitionAwareComponent<P extends object>(
61
61
  style,
62
62
  });
63
63
 
64
- const {
65
- handleInitialLayout,
66
- captureActiveOnPress,
67
- MeasurementSyncProvider,
68
- } = useBoundsRegistry({
69
- sharedBoundTag,
70
- animatedRef,
71
- style,
72
- onPress,
73
- });
74
-
75
64
  return (
76
- <MeasurementSyncProvider>
77
- <AnimatedComponent
78
- {...(rest as Any)}
79
- ref={animatedRef}
80
- style={[style, associatedStyles]}
81
- onPress={captureActiveOnPress}
82
- onLayout={runOnUI(handleInitialLayout)}
83
- collapsable={!sharedBoundTag}
84
- >
85
- {children}
86
- </AnimatedComponent>
87
- </MeasurementSyncProvider>
65
+ <RegisterBoundsProvider
66
+ animatedRef={animatedRef}
67
+ style={style}
68
+ onPress={onPress}
69
+ sharedBoundTag={sharedBoundTag}
70
+ >
71
+ {({ captureActiveOnPress, handleInitialLayout }) => (
72
+ <AnimatedComponent
73
+ {...(rest as Any)}
74
+ ref={animatedRef}
75
+ style={[style, associatedStyles]}
76
+ onPress={captureActiveOnPress}
77
+ onLayout={runOnUI(handleInitialLayout)}
78
+ collapsable={!sharedBoundTag}
79
+ >
80
+ {children}
81
+ </AnimatedComponent>
82
+ )}
83
+ </RegisterBoundsProvider>
88
84
  );
89
85
  });
90
86
 
@@ -2,7 +2,7 @@ import { memo } from "react";
2
2
  import { StyleSheet, View } from "react-native";
3
3
  import Animated, { useAnimatedStyle } from "react-native-reanimated";
4
4
  import { NO_STYLES } from "../constants";
5
- import { useTransitionStyles } from "../providers/transition-styles";
5
+ import { useTransitionStyles } from "../providers/transition-styles.provider";
6
6
 
7
7
  type Props = {
8
8
  children: React.ReactNode;
@@ -4,7 +4,7 @@ import {
4
4
  interpolate,
5
5
  interpolateColor,
6
6
  } from "react-native-reanimated";
7
- import type { ScreenTransitionConfig } from "../types/core";
7
+ import type { ScreenTransitionConfig } from "../types/core.types";
8
8
  import { DefaultSpec } from "./specs";
9
9
 
10
10
  const platform = Platform.OS;
@@ -216,9 +216,12 @@ export const ElasticCard = (
216
216
  };
217
217
  };
218
218
 
219
- export const SharedIGImage = (
220
- config: Partial<ScreenTransitionConfig> = {},
221
- ): ScreenTransitionConfig => {
219
+ export const SharedIGImage = ({
220
+ sharedBoundTag,
221
+ ...config
222
+ }: Partial<ScreenTransitionConfig> & {
223
+ sharedBoundTag: string;
224
+ }): ScreenTransitionConfig => {
222
225
  return {
223
226
  gestureEnabled: true,
224
227
  gestureDirection: ["vertical", "horizontal"],
@@ -232,7 +235,6 @@ export const SharedIGImage = (
232
235
  bounds,
233
236
  progress,
234
237
  focused,
235
- activeBoundId,
236
238
  active,
237
239
  }) => {
238
240
  "worklet";
@@ -257,6 +259,7 @@ export const SharedIGImage = (
257
259
  const dragYScale = interpolate(normY, [0, 1], [1, 0.8]);
258
260
 
259
261
  const boundValues = bounds({
262
+ id: sharedBoundTag,
260
263
  method: focused ? "content" : "transform",
261
264
  scaleMode: "uniform",
262
265
  raw: true,
@@ -265,6 +268,7 @@ export const SharedIGImage = (
265
268
  // focused specific animations
266
269
  if (focused) {
267
270
  const maskedValues = bounds({
271
+ id: sharedBoundTag,
268
272
  space: "absolute",
269
273
  target: "fullscreen",
270
274
  method: "size",
@@ -309,7 +313,7 @@ export const SharedIGImage = (
309
313
  contentStyle: {
310
314
  pointerEvents: current.gesture.isDismissing ? "none" : "auto",
311
315
  },
312
- [activeBoundId]: {
316
+ [sharedBoundTag]: {
313
317
  transform: [
314
318
  { translateX: dragX || 0 },
315
319
  { translateY: dragY || 0 },
@@ -345,9 +349,12 @@ export const SharedIGImage = (
345
349
  };
346
350
  };
347
351
 
348
- export const SharedAppleMusic = (
349
- config: Partial<ScreenTransitionConfig> = {},
350
- ): ScreenTransitionConfig => {
352
+ export const SharedAppleMusic = ({
353
+ sharedBoundTag,
354
+ ...config
355
+ }: Partial<ScreenTransitionConfig> & {
356
+ sharedBoundTag: string;
357
+ }): ScreenTransitionConfig => {
351
358
  return {
352
359
  enableTransitions: true,
353
360
  gestureEnabled: true,
@@ -355,7 +362,6 @@ export const SharedAppleMusic = (
355
362
  gestureDrivesProgress: false,
356
363
  screenStyleInterpolator: ({
357
364
  bounds,
358
- activeBoundId,
359
365
  focused,
360
366
  progress,
361
367
  layouts: { screen },
@@ -395,6 +401,7 @@ export const SharedAppleMusic = (
395
401
  const dragYScale = interpolate(normY, [0, 1], yScaleOuput);
396
402
 
397
403
  const boundValues = bounds({
404
+ id: sharedBoundTag,
398
405
  method: focused ? "content" : "transform",
399
406
  anchor: "top",
400
407
  scaleMode: "uniform",
@@ -415,6 +422,7 @@ export const SharedAppleMusic = (
415
422
  */
416
423
  if (focused) {
417
424
  const maskedValues = bounds({
425
+ id: sharedBoundTag,
418
426
  space: "absolute",
419
427
  method: "size",
420
428
  target: "fullscreen",
@@ -501,7 +509,7 @@ export const SharedAppleMusic = (
501
509
  const contentScale = interpolate(progress, [1, 2], [1, 0.9], "clamp");
502
510
 
503
511
  return {
504
- [activeBoundId]: {
512
+ [sharedBoundTag]: {
505
513
  transform: [
506
514
  { translateX: dragX || 0 },
507
515
  { translateY: dragY || 0 },
@@ -544,9 +552,12 @@ export const SharedAppleMusic = (
544
552
  };
545
553
  };
546
554
 
547
- export const SharedXImage = (
548
- config: Partial<ScreenTransitionConfig> = {},
549
- ): ScreenTransitionConfig => {
555
+ export const SharedXImage = ({
556
+ sharedBoundTag,
557
+ ...config
558
+ }: Partial<ScreenTransitionConfig> & {
559
+ sharedBoundTag: string;
560
+ }): ScreenTransitionConfig => {
550
561
  return {
551
562
  enableTransitions: true,
552
563
  gestureEnabled: true,
@@ -554,7 +565,6 @@ export const SharedXImage = (
554
565
  gestureDrivesProgress: false,
555
566
  screenStyleInterpolator: ({
556
567
  focused,
557
- activeBoundId,
558
568
  bounds,
559
569
  current,
560
570
  layouts: { screen },
@@ -565,7 +575,11 @@ export const SharedXImage = (
565
575
  // twitter doesn't animate the unfocused screen
566
576
  if (!focused) return {};
567
577
 
568
- const boundValues = bounds({ method: "transform", raw: true });
578
+ const boundValues = bounds({
579
+ id: sharedBoundTag,
580
+ method: "transform",
581
+ raw: true,
582
+ });
569
583
 
570
584
  // content styles
571
585
  const dragY = interpolate(
@@ -596,7 +610,7 @@ export const SharedXImage = (
596
610
  const scaleY = !current.closing ? boundValues.scaleY : 1;
597
611
 
598
612
  return {
599
- [activeBoundId]: {
613
+ [sharedBoundTag]: {
600
614
  transform: [
601
615
  {
602
616
  translateX: x,
@@ -1,11 +1,11 @@
1
1
  import type { ParamListBase, RouteProp } from "@react-navigation/native";
2
2
  import type { MeasuredDimensions } from "react-native-reanimated";
3
- import type { ScreenTransitionState } from "./types/animation";
4
- import type { BoundEntry } from "./types/bounds";
5
- import type { Layout } from "./types/core";
6
- import type { ActivationArea } from "./types/gesture";
7
- import type { Complete } from "./types/utils";
8
- import type { BoundsBuilderOptions } from "./utils/bounds/_types/builder";
3
+ import type { ScreenTransitionState } from "./types/animation.types";
4
+ import type { BoundEntry } from "./types/bounds.types";
5
+ import type { Layout } from "./types/core.types";
6
+ import type { ActivationArea } from "./types/gesture.types";
7
+ import type { Complete } from "./types/utils.types";
8
+ import type { BoundsBuilderOptions } from "./utils/bounds/types/builder";
9
9
 
10
10
  /**
11
11
  * Masked view integration
@@ -35,7 +35,6 @@ export const DEFAULT_SCREEN_TRANSITION_STATE: ScreenTransitionState =
35
35
  isDragging: 0,
36
36
  direction: null,
37
37
  },
38
- bounds: {} as Record<string, BoundEntry>,
39
38
  route: {} as RouteProp<ParamListBase>,
40
39
  });
41
40
 
@@ -5,7 +5,7 @@ import {
5
5
  useSharedValue,
6
6
  } from "react-native-reanimated";
7
7
  import { NO_STYLES } from "../../constants";
8
- import { useTransitionStyles } from "../../providers/transition-styles";
8
+ import { useTransitionStyles } from "../../providers/transition-styles.provider";
9
9
 
10
10
  type Props = {
11
11
  id?: string;
@@ -16,14 +16,12 @@ type Props = {
16
16
  * This hook is used to get the associated styles for a given styleId / boundTag.
17
17
  */
18
18
  export const useAssociatedStyles = ({ id }: Props = {}) => {
19
- const { stylesMap } = useTransitionStyles();
19
+ const { stylesMap, ancestorStylesMaps } = useTransitionStyles();
20
20
  const showAfterFirstFrame = useSharedValue(false);
21
21
 
22
22
  useDerivedValue(() => {
23
23
  "worklet";
24
24
 
25
- // If the associated styles have already been shown, return.
26
-
27
25
  if (!id) {
28
26
  showAfterFirstFrame.value = true;
29
27
  return;
@@ -39,10 +37,18 @@ export const useAssociatedStyles = ({ id }: Props = {}) => {
39
37
  const associatedStyles = useAnimatedStyle(() => {
40
38
  "worklet";
41
39
 
42
- if (!id || !stylesMap) {
40
+ if (!id) {
43
41
  return NO_STYLES;
44
42
  }
45
- const base = stylesMap.value[id] || NO_STYLES;
43
+
44
+ // Check local styles first, then fall back to parent
45
+ const ownStyle = stylesMap.value[id];
46
+
47
+ const ancestorStyle = ancestorStylesMaps.find(
48
+ (ancestorMap) => ancestorMap.value[id],
49
+ )?.value[id];
50
+
51
+ const base = ownStyle || ancestorStyle || NO_STYLES;
46
52
 
47
53
  let opacity = 1;
48
54
 
@@ -50,13 +56,10 @@ export const useAssociatedStyles = ({ id }: Props = {}) => {
50
56
  opacity = base.opacity as number;
51
57
  }
52
58
 
53
- // Only force opacity to 0 during the initial frame; once ready,
54
- // return base unchanged so we never override user-provided opacity.
55
59
  if (!showAfterFirstFrame.value) {
56
60
  return { ...base, opacity: 0 };
57
61
  }
58
62
 
59
- // Since opacity exists on the base style, we don't need to override it.
60
63
  if ("opacity" in base) {
61
64
  return base;
62
65
  }
@@ -4,18 +4,15 @@ import { useWindowDimensions } from "react-native";
4
4
  import { type SharedValue, useDerivedValue } from "react-native-reanimated";
5
5
  import { useSafeAreaInsets } from "react-native-safe-area-context";
6
6
 
7
- import {
8
- DEFAULT_SCREEN_TRANSITION_STATE,
9
- NO_BOUNDS_MAP,
10
- } from "../../constants";
11
- import { type TransitionDescriptor, useKeys } from "../../providers/keys";
12
- import { AnimationStore } from "../../stores/animation-store";
13
- import { BoundStore } from "../../stores/bound-store";
14
- import { GestureStore, type GestureStoreMap } from "../../stores/gesture-store";
7
+ import { DEFAULT_SCREEN_TRANSITION_STATE } from "../../constants";
8
+ import { type TransitionDescriptor, useKeys } from "../../providers/keys.provider";
9
+
10
+ import { AnimationStore } from "../../stores/animation.store";
11
+ import { GestureStore, type GestureStoreMap } from "../../stores/gesture.store";
15
12
  import type {
16
13
  ScreenInterpolationProps,
17
14
  ScreenTransitionState,
18
- } from "../../types/animation";
15
+ } from "../../types/animation.types";
19
16
  import { derivations } from "../../utils/animation/derivations";
20
17
  import { createBounds } from "../../utils/bounds";
21
18
 
@@ -47,7 +44,6 @@ const unwrap = (
47
44
  isDragging: s.gesture.isDragging.value,
48
45
  direction: s.gesture.direction.value,
49
46
  },
50
- bounds: BoundStore.getBounds(key) || NO_BOUNDS_MAP,
51
47
  route: s.route,
52
48
  };
53
49
  };
@@ -99,17 +95,9 @@ export function _useScreenAnimation() {
99
95
  unwrap(currentAnimation, currentDescriptor?.route.key) ??
100
96
  DEFAULT_SCREEN_TRANSITION_STATE;
101
97
 
102
- const {
103
- progress,
104
- focused,
105
- activeBoundId,
106
- active,
107
- isActiveTransitioning,
108
- isDismissing,
109
- } = derivations({
98
+ const helpers = derivations({
110
99
  current,
111
100
  next,
112
- previous,
113
101
  });
114
102
 
115
103
  return {
@@ -118,13 +106,7 @@ export function _useScreenAnimation() {
118
106
  previous,
119
107
  current,
120
108
  next,
121
- focused,
122
- activeBoundId,
123
- progress,
124
-
125
- active,
126
- isActiveTransitioning,
127
- isDismissing,
109
+ ...helpers,
128
110
  };
129
111
  });
130
112
 
@@ -21,12 +21,12 @@ import {
21
21
  import type {
22
22
  GestureContextType,
23
23
  ScrollConfig,
24
- } from "../../providers/gestures";
25
- import { useKeys } from "../../providers/keys";
26
- import { AnimationStore } from "../../stores/animation-store";
27
- import { GestureStore, type GestureStoreMap } from "../../stores/gesture-store";
24
+ } from "../../providers/gestures.provider";
25
+ import { useKeys } from "../../providers/keys.provider";
26
+ import { AnimationStore } from "../../stores/animation.store";
27
+ import { GestureStore, type GestureStoreMap } from "../../stores/gesture.store";
28
28
 
29
- import { type GestureDirection, GestureOffsetState } from "../../types/gesture";
29
+ import { type GestureDirection, GestureOffsetState } from "../../types/gesture.types";
30
30
  import { startScreenTransition } from "../../utils/animation/start-screen-transition";
31
31
  import { applyOffsetRules } from "../../utils/gesture/check-gesture-activation";
32
32
  import { determineDismissal } from "../../utils/gesture/determine-dismissal";
@@ -1,5 +1,5 @@
1
1
  import { useEffect } from "react";
2
- import { useGestureContext } from "../../providers/gestures";
2
+ import { useGestureContext } from "../../providers/gestures.provider";
3
3
  import useStableCallback from "../use-stable-callback";
4
4
 
5
5
  /**
@@ -14,7 +14,5 @@ export const useParentGestureRegistry = () => {
14
14
  }
15
15
  });
16
16
 
17
- useEffect(() => {
18
- registerNativeGesture();
19
- }, [registerNativeGesture]);
17
+ useEffect(registerNativeGesture);
20
18
  };
@@ -1,8 +1,8 @@
1
1
  import type { LayoutChangeEvent } from "react-native";
2
2
  import { useAnimatedScrollHandler } from "react-native-reanimated";
3
3
  import type { ReanimatedScrollEvent } from "react-native-reanimated/lib/typescript/hook/commonTypes";
4
- import { useGestureContext } from "../../providers/gestures";
5
- import type { Any } from "../../types/utils";
4
+ import { useGestureContext } from "../../providers/gestures.provider";
5
+ import type { Any } from "../../types/utils.types";
6
6
  import useStableCallback from "../use-stable-callback";
7
7
 
8
8
  interface ScrollProgressHookProps {
@@ -25,5 +25,5 @@ export type {
25
25
  OverlayInterpolationProps,
26
26
  ScreenInterpolationProps,
27
27
  ScreenStyleInterpolator,
28
- } from "./types/animation";
29
- export type { ScreenTransitionConfig } from "./types/core";
28
+ } from "./types/animation.types";
29
+ export type { ScreenTransitionConfig } from "./types/core.types";
@@ -5,7 +5,7 @@ import { GestureDetector } from "react-native-gesture-handler";
5
5
  import type { SharedValue } from "react-native-reanimated";
6
6
  import { useSharedValue } from "react-native-reanimated";
7
7
  import { useBuildGestures } from "../hooks/gestures/use-build-gestures";
8
- import type { GestureStoreMap } from "../stores/gesture-store";
8
+ import type { GestureStoreMap } from "../stores/gesture.store";
9
9
 
10
10
  export type ScrollConfig = {
11
11
  x: number;
@@ -5,7 +5,7 @@ import type {
5
5
  RouteProp,
6
6
  } from "@react-navigation/native";
7
7
  import { createContext, useContext, useMemo } from "react";
8
- import type { ScreenTransitionConfig } from "../types/core";
8
+ import type { ScreenTransitionConfig } from "../types/core.types";
9
9
 
10
10
  export type TransitionDescriptor = Descriptor<
11
11
  ScreenTransitionConfig,