@react-navigation/core 7.0.0-alpha.1 → 7.0.0-alpha.11

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 (350) hide show
  1. package/lib/commonjs/BaseNavigationContainer.js +25 -30
  2. package/lib/commonjs/BaseNavigationContainer.js.map +1 -1
  3. package/lib/commonjs/CurrentRenderContext.js +3 -4
  4. package/lib/commonjs/CurrentRenderContext.js.map +1 -1
  5. package/lib/commonjs/DeprecatedNavigationInChildContext.js +3 -4
  6. package/lib/commonjs/DeprecatedNavigationInChildContext.js.map +1 -1
  7. package/lib/commonjs/EnsureSingleNavigator.js +3 -4
  8. package/lib/commonjs/EnsureSingleNavigator.js.map +1 -1
  9. package/lib/commonjs/Group.js.map +1 -1
  10. package/lib/commonjs/NavigationBuilderContext.js +3 -4
  11. package/lib/commonjs/NavigationBuilderContext.js.map +1 -1
  12. package/lib/commonjs/NavigationContainerRefContext.js +3 -4
  13. package/lib/commonjs/NavigationContainerRefContext.js.map +1 -1
  14. package/lib/commonjs/NavigationContext.js +3 -4
  15. package/lib/commonjs/NavigationContext.js.map +1 -1
  16. package/lib/commonjs/NavigationHelpersContext.js +3 -4
  17. package/lib/commonjs/NavigationHelpersContext.js.map +1 -1
  18. package/lib/commonjs/NavigationIndependentTree.js +2 -2
  19. package/lib/commonjs/NavigationIndependentTree.js.map +1 -1
  20. package/lib/commonjs/NavigationIndependentTreeContext.js +3 -4
  21. package/lib/commonjs/NavigationIndependentTreeContext.js.map +1 -1
  22. package/lib/commonjs/NavigationRouteContext.js +3 -4
  23. package/lib/commonjs/NavigationRouteContext.js.map +1 -1
  24. package/lib/commonjs/NavigationStateContext.js +3 -4
  25. package/lib/commonjs/NavigationStateContext.js.map +1 -1
  26. package/lib/commonjs/PreventRemoveContext.js +8 -4
  27. package/lib/commonjs/PreventRemoveContext.js.map +1 -1
  28. package/lib/commonjs/PreventRemoveProvider.js +8 -10
  29. package/lib/commonjs/PreventRemoveProvider.js.map +1 -1
  30. package/lib/commonjs/SceneView.js +2 -2
  31. package/lib/commonjs/SceneView.js.map +1 -1
  32. package/lib/commonjs/Screen.js.map +1 -1
  33. package/lib/commonjs/StaticContainer.js +3 -4
  34. package/lib/commonjs/StaticContainer.js.map +1 -1
  35. package/lib/commonjs/StaticNavigation.js +34 -7
  36. package/lib/commonjs/StaticNavigation.js.map +1 -1
  37. package/lib/commonjs/UnhandledActionContext.js +3 -4
  38. package/lib/commonjs/UnhandledActionContext.js.map +1 -1
  39. package/lib/commonjs/checkDuplicateRouteNames.js +1 -2
  40. package/lib/commonjs/checkDuplicateRouteNames.js.map +1 -1
  41. package/lib/commonjs/checkSerializable.js.map +1 -1
  42. package/lib/commonjs/createNavigationContainerRef.js +1 -2
  43. package/lib/commonjs/createNavigationContainerRef.js.map +1 -1
  44. package/lib/commonjs/createNavigatorFactory.js +0 -3
  45. package/lib/commonjs/createNavigatorFactory.js.map +1 -1
  46. package/lib/commonjs/findFocusedRoute.js +2 -4
  47. package/lib/commonjs/findFocusedRoute.js.map +1 -1
  48. package/lib/commonjs/getActionFromState.js +6 -8
  49. package/lib/commonjs/getActionFromState.js.map +1 -1
  50. package/lib/commonjs/getFocusedRouteNameFromRoute.js +1 -1
  51. package/lib/commonjs/getFocusedRouteNameFromRoute.js.map +1 -1
  52. package/lib/commonjs/getPathFromState.js +25 -22
  53. package/lib/commonjs/getPathFromState.js.map +1 -1
  54. package/lib/commonjs/getStateFromPath.js +63 -21
  55. package/lib/commonjs/getStateFromPath.js.map +1 -1
  56. package/lib/commonjs/index.js +27 -3
  57. package/lib/commonjs/index.js.map +1 -1
  58. package/lib/commonjs/isArrayEqual.js.map +1 -1
  59. package/lib/commonjs/isRecordEqual.js.map +1 -1
  60. package/lib/commonjs/theming/ThemeContext.js +12 -0
  61. package/lib/commonjs/theming/ThemeContext.js.map +1 -0
  62. package/lib/commonjs/theming/ThemeProvider.js +20 -0
  63. package/lib/commonjs/theming/ThemeProvider.js.map +1 -0
  64. package/lib/commonjs/theming/useTheme.js +18 -0
  65. package/lib/commonjs/theming/useTheme.js.map +1 -0
  66. package/lib/commonjs/types.js.map +1 -1
  67. package/lib/commonjs/useChildListeners.js +2 -2
  68. package/lib/commonjs/useChildListeners.js.map +1 -1
  69. package/lib/commonjs/useComponent.js +2 -2
  70. package/lib/commonjs/useComponent.js.map +1 -1
  71. package/lib/commonjs/useCurrentRender.js +2 -2
  72. package/lib/commonjs/useCurrentRender.js.map +1 -1
  73. package/lib/commonjs/useDescriptors.js +83 -31
  74. package/lib/commonjs/useDescriptors.js.map +1 -1
  75. package/lib/commonjs/useEventEmitter.js +5 -6
  76. package/lib/commonjs/useEventEmitter.js.map +1 -1
  77. package/lib/commonjs/useFocusEffect.js +4 -2
  78. package/lib/commonjs/useFocusEffect.js.map +1 -1
  79. package/lib/commonjs/useFocusEvents.js +4 -4
  80. package/lib/commonjs/useFocusEvents.js.map +1 -1
  81. package/lib/commonjs/useFocusedListenersChildrenAdapter.js +3 -3
  82. package/lib/commonjs/useFocusedListenersChildrenAdapter.js.map +1 -1
  83. package/lib/commonjs/useIsFocused.js +5 -4
  84. package/lib/commonjs/useIsFocused.js.map +1 -1
  85. package/lib/commonjs/useIsomorphicLayoutEffect.js +12 -0
  86. package/lib/commonjs/useIsomorphicLayoutEffect.js.map +1 -0
  87. package/lib/commonjs/useIsomorphicLayoutEffect.native.js +9 -0
  88. package/lib/commonjs/useIsomorphicLayoutEffect.native.js.map +1 -0
  89. package/lib/commonjs/useKeyedChildListeners.js +2 -2
  90. package/lib/commonjs/useKeyedChildListeners.js.map +1 -1
  91. package/lib/commonjs/useNavigation.js +2 -2
  92. package/lib/commonjs/useNavigation.js.map +1 -1
  93. package/lib/commonjs/useNavigationBuilder.js +81 -68
  94. package/lib/commonjs/useNavigationBuilder.js.map +1 -1
  95. package/lib/commonjs/useNavigationCache.js +57 -16
  96. package/lib/commonjs/useNavigationCache.js.map +1 -1
  97. package/lib/commonjs/useNavigationContainerRef.js +2 -2
  98. package/lib/commonjs/useNavigationContainerRef.js.map +1 -1
  99. package/lib/commonjs/useNavigationHelpers.js +4 -5
  100. package/lib/commonjs/useNavigationHelpers.js.map +1 -1
  101. package/lib/commonjs/useNavigationIndependentTree.js +2 -2
  102. package/lib/commonjs/useNavigationIndependentTree.js.map +1 -1
  103. package/lib/commonjs/useNavigationState.js +2 -2
  104. package/lib/commonjs/useNavigationState.js.map +1 -1
  105. package/lib/commonjs/useOnAction.js +6 -4
  106. package/lib/commonjs/useOnAction.js.map +1 -1
  107. package/lib/commonjs/useOnGetState.js +4 -5
  108. package/lib/commonjs/useOnGetState.js.map +1 -1
  109. package/lib/commonjs/useOnPreventRemove.js +5 -6
  110. package/lib/commonjs/useOnPreventRemove.js.map +1 -1
  111. package/lib/commonjs/useOnRouteFocus.js +2 -2
  112. package/lib/commonjs/useOnRouteFocus.js.map +1 -1
  113. package/lib/commonjs/useOptionsGetters.js +9 -10
  114. package/lib/commonjs/useOptionsGetters.js.map +1 -1
  115. package/lib/commonjs/usePreventRemove.js +5 -5
  116. package/lib/commonjs/usePreventRemove.js.map +1 -1
  117. package/lib/commonjs/usePreventRemoveContext.js +2 -2
  118. package/lib/commonjs/usePreventRemoveContext.js.map +1 -1
  119. package/lib/commonjs/useRegisterNavigator.js +2 -2
  120. package/lib/commonjs/useRegisterNavigator.js.map +1 -1
  121. package/lib/commonjs/useRoute.js +2 -2
  122. package/lib/commonjs/useRoute.js.map +1 -1
  123. package/lib/commonjs/useRouteCache.js +19 -16
  124. package/lib/commonjs/useRouteCache.js.map +1 -1
  125. package/lib/commonjs/useSyncState.js +27 -56
  126. package/lib/commonjs/useSyncState.js.map +1 -1
  127. package/lib/commonjs/validatePathConfig.js +37 -10
  128. package/lib/commonjs/validatePathConfig.js.map +1 -1
  129. package/lib/module/BaseNavigationContainer.js +22 -26
  130. package/lib/module/BaseNavigationContainer.js.map +1 -1
  131. package/lib/module/CurrentRenderContext.js.map +1 -1
  132. package/lib/module/DeprecatedNavigationInChildContext.js.map +1 -1
  133. package/lib/module/EnsureSingleNavigator.js.map +1 -1
  134. package/lib/module/Group.js.map +1 -1
  135. package/lib/module/NavigationBuilderContext.js.map +1 -1
  136. package/lib/module/NavigationContainerRefContext.js.map +1 -1
  137. package/lib/module/NavigationContext.js.map +1 -1
  138. package/lib/module/NavigationHelpersContext.js.map +1 -1
  139. package/lib/module/NavigationIndependentTree.js.map +1 -1
  140. package/lib/module/NavigationIndependentTreeContext.js.map +1 -1
  141. package/lib/module/NavigationRouteContext.js.map +1 -1
  142. package/lib/module/NavigationStateContext.js.map +1 -1
  143. package/lib/module/PreventRemoveContext.js.map +1 -1
  144. package/lib/module/PreventRemoveProvider.js +6 -8
  145. package/lib/module/PreventRemoveProvider.js.map +1 -1
  146. package/lib/module/SceneView.js.map +1 -1
  147. package/lib/module/Screen.js.map +1 -1
  148. package/lib/module/StaticContainer.js.map +1 -1
  149. package/lib/module/StaticNavigation.js +27 -5
  150. package/lib/module/StaticNavigation.js.map +1 -1
  151. package/lib/module/UnhandledActionContext.js.map +1 -1
  152. package/lib/module/checkDuplicateRouteNames.js +1 -2
  153. package/lib/module/checkDuplicateRouteNames.js.map +1 -1
  154. package/lib/module/checkSerializable.js.map +1 -1
  155. package/lib/module/createNavigationContainerRef.js.map +1 -1
  156. package/lib/module/createNavigatorFactory.js +0 -3
  157. package/lib/module/createNavigatorFactory.js.map +1 -1
  158. package/lib/module/findFocusedRoute.js +2 -4
  159. package/lib/module/findFocusedRoute.js.map +1 -1
  160. package/lib/module/getActionFromState.js +6 -8
  161. package/lib/module/getActionFromState.js.map +1 -1
  162. package/lib/module/getFocusedRouteNameFromRoute.js +1 -1
  163. package/lib/module/getFocusedRouteNameFromRoute.js.map +1 -1
  164. package/lib/module/getPathFromState.js +23 -20
  165. package/lib/module/getPathFromState.js.map +1 -1
  166. package/lib/module/getStateFromPath.js +61 -19
  167. package/lib/module/getStateFromPath.js.map +1 -1
  168. package/lib/module/index.js +4 -1
  169. package/lib/module/index.js.map +1 -1
  170. package/lib/module/isArrayEqual.js.map +1 -1
  171. package/lib/module/isRecordEqual.js.map +1 -1
  172. package/lib/module/theming/ThemeContext.js +4 -0
  173. package/lib/module/theming/ThemeContext.js.map +1 -0
  174. package/lib/module/theming/ThemeProvider.js +12 -0
  175. package/lib/module/theming/ThemeProvider.js.map +1 -0
  176. package/lib/module/theming/useTheme.js +10 -0
  177. package/lib/module/theming/useTheme.js.map +1 -0
  178. package/lib/module/types.js.map +1 -1
  179. package/lib/module/useChildListeners.js.map +1 -1
  180. package/lib/module/useComponent.js.map +1 -1
  181. package/lib/module/useCurrentRender.js.map +1 -1
  182. package/lib/module/useDescriptors.js +81 -29
  183. package/lib/module/useDescriptors.js.map +1 -1
  184. package/lib/module/useEventEmitter.js +3 -4
  185. package/lib/module/useEventEmitter.js.map +1 -1
  186. package/lib/module/useFocusEffect.js +2 -0
  187. package/lib/module/useFocusEffect.js.map +1 -1
  188. package/lib/module/useFocusEvents.js +2 -2
  189. package/lib/module/useFocusEvents.js.map +1 -1
  190. package/lib/module/useFocusedListenersChildrenAdapter.js +1 -1
  191. package/lib/module/useFocusedListenersChildrenAdapter.js.map +1 -1
  192. package/lib/module/useIsFocused.js.map +1 -1
  193. package/lib/module/useIsomorphicLayoutEffect.js +7 -0
  194. package/lib/module/useIsomorphicLayoutEffect.js.map +1 -0
  195. package/lib/module/useIsomorphicLayoutEffect.native.js +3 -0
  196. package/lib/module/useIsomorphicLayoutEffect.native.js.map +1 -0
  197. package/lib/module/useKeyedChildListeners.js.map +1 -1
  198. package/lib/module/useNavigation.js.map +1 -1
  199. package/lib/module/useNavigationBuilder.js +78 -66
  200. package/lib/module/useNavigationBuilder.js.map +1 -1
  201. package/lib/module/useNavigationCache.js +55 -14
  202. package/lib/module/useNavigationCache.js.map +1 -1
  203. package/lib/module/useNavigationContainerRef.js.map +1 -1
  204. package/lib/module/useNavigationHelpers.js +2 -3
  205. package/lib/module/useNavigationHelpers.js.map +1 -1
  206. package/lib/module/useNavigationIndependentTree.js.map +1 -1
  207. package/lib/module/useNavigationState.js.map +1 -1
  208. package/lib/module/useOnAction.js +4 -2
  209. package/lib/module/useOnAction.js.map +1 -1
  210. package/lib/module/useOnGetState.js +2 -3
  211. package/lib/module/useOnGetState.js.map +1 -1
  212. package/lib/module/useOnPreventRemove.js +3 -4
  213. package/lib/module/useOnPreventRemove.js.map +1 -1
  214. package/lib/module/useOnRouteFocus.js.map +1 -1
  215. package/lib/module/useOptionsGetters.js +7 -8
  216. package/lib/module/useOptionsGetters.js.map +1 -1
  217. package/lib/module/usePreventRemove.js +2 -2
  218. package/lib/module/usePreventRemove.js.map +1 -1
  219. package/lib/module/usePreventRemoveContext.js.map +1 -1
  220. package/lib/module/useRegisterNavigator.js.map +1 -1
  221. package/lib/module/useRoute.js.map +1 -1
  222. package/lib/module/useRouteCache.js +16 -12
  223. package/lib/module/useRouteCache.js.map +1 -1
  224. package/lib/module/useSyncState.js +25 -54
  225. package/lib/module/useSyncState.js.map +1 -1
  226. package/lib/module/validatePathConfig.js +37 -10
  227. package/lib/module/validatePathConfig.js.map +1 -1
  228. package/lib/typescript/src/BaseNavigationContainer.d.ts +2 -1
  229. package/lib/typescript/src/BaseNavigationContainer.d.ts.map +1 -1
  230. package/lib/typescript/src/EnsureSingleNavigator.d.ts +1 -1
  231. package/lib/typescript/src/EnsureSingleNavigator.d.ts.map +1 -1
  232. package/lib/typescript/src/NavigationContext.d.ts +1 -17
  233. package/lib/typescript/src/NavigationContext.d.ts.map +1 -1
  234. package/lib/typescript/src/NavigationHelpersContext.d.ts +1 -1
  235. package/lib/typescript/src/NavigationHelpersContext.d.ts.map +1 -1
  236. package/lib/typescript/src/NavigationIndependentTree.d.ts +1 -1
  237. package/lib/typescript/src/NavigationIndependentTree.d.ts.map +1 -1
  238. package/lib/typescript/src/NavigationRouteContext.d.ts +1 -1
  239. package/lib/typescript/src/NavigationRouteContext.d.ts.map +1 -1
  240. package/lib/typescript/src/NavigationStateContext.d.ts +2 -18
  241. package/lib/typescript/src/NavigationStateContext.d.ts.map +1 -1
  242. package/lib/typescript/src/PreventRemoveProvider.d.ts +1 -1
  243. package/lib/typescript/src/PreventRemoveProvider.d.ts.map +1 -1
  244. package/lib/typescript/src/SceneView.d.ts +2 -2
  245. package/lib/typescript/src/SceneView.d.ts.map +1 -1
  246. package/lib/typescript/src/StaticNavigation.d.ts +12 -5
  247. package/lib/typescript/src/StaticNavigation.d.ts.map +1 -1
  248. package/lib/typescript/src/createNavigatorFactory.d.ts.map +1 -1
  249. package/lib/typescript/src/findFocusedRoute.d.ts +1 -9
  250. package/lib/typescript/src/findFocusedRoute.d.ts.map +1 -1
  251. package/lib/typescript/src/getPathFromState.d.ts +1 -0
  252. package/lib/typescript/src/getPathFromState.d.ts.map +1 -1
  253. package/lib/typescript/src/getStateFromPath.d.ts +1 -0
  254. package/lib/typescript/src/getStateFromPath.d.ts.map +1 -1
  255. package/lib/typescript/src/index.d.ts +5 -2
  256. package/lib/typescript/src/index.d.ts.map +1 -1
  257. package/lib/typescript/src/theming/ThemeContext.d.ts +3 -0
  258. package/lib/typescript/src/theming/ThemeContext.d.ts.map +1 -0
  259. package/lib/typescript/src/theming/ThemeProvider.d.ts +8 -0
  260. package/lib/typescript/src/theming/ThemeProvider.d.ts.map +1 -0
  261. package/lib/typescript/src/theming/useTheme.d.ts +2 -0
  262. package/lib/typescript/src/theming/useTheme.d.ts.map +1 -0
  263. package/lib/typescript/src/types.d.ts +80 -1
  264. package/lib/typescript/src/types.d.ts.map +1 -1
  265. package/lib/typescript/src/useComponent.d.ts +1 -1
  266. package/lib/typescript/src/useComponent.d.ts.map +1 -1
  267. package/lib/typescript/src/useDescriptors.d.ts +107 -59
  268. package/lib/typescript/src/useDescriptors.d.ts.map +1 -1
  269. package/lib/typescript/src/useFocusEffect.d.ts.map +1 -1
  270. package/lib/typescript/src/useFocusedListenersChildrenAdapter.d.ts +1 -1
  271. package/lib/typescript/src/useFocusedListenersChildrenAdapter.d.ts.map +1 -1
  272. package/lib/typescript/src/useIsomorphicLayoutEffect.d.ts +6 -0
  273. package/lib/typescript/src/useIsomorphicLayoutEffect.d.ts.map +1 -0
  274. package/lib/typescript/src/useIsomorphicLayoutEffect.native.d.ts +3 -0
  275. package/lib/typescript/src/useIsomorphicLayoutEffect.native.d.ts.map +1 -0
  276. package/lib/typescript/src/useNavigation.d.ts +4 -1
  277. package/lib/typescript/src/useNavigation.d.ts.map +1 -1
  278. package/lib/typescript/src/useNavigationBuilder.d.ts +99 -63
  279. package/lib/typescript/src/useNavigationBuilder.d.ts.map +1 -1
  280. package/lib/typescript/src/useNavigationCache.d.ts +53 -3
  281. package/lib/typescript/src/useNavigationCache.d.ts.map +1 -1
  282. package/lib/typescript/src/useNavigationHelpers.d.ts +25 -55
  283. package/lib/typescript/src/useNavigationHelpers.d.ts.map +1 -1
  284. package/lib/typescript/src/useOnAction.d.ts +1 -1
  285. package/lib/typescript/src/useOnAction.d.ts.map +1 -1
  286. package/lib/typescript/src/useOnGetState.d.ts +1 -1
  287. package/lib/typescript/src/useOnGetState.d.ts.map +1 -1
  288. package/lib/typescript/src/useOnPreventRemove.d.ts +1 -1
  289. package/lib/typescript/src/useOnPreventRemove.d.ts.map +1 -1
  290. package/lib/typescript/src/usePreventRemove.d.ts +1 -1
  291. package/lib/typescript/src/usePreventRemove.d.ts.map +1 -1
  292. package/lib/typescript/src/useRouteCache.d.ts +1 -1
  293. package/lib/typescript/src/useRouteCache.d.ts.map +1 -1
  294. package/lib/typescript/src/useSyncState.d.ts +1 -4
  295. package/lib/typescript/src/useSyncState.d.ts.map +1 -1
  296. package/lib/typescript/src/validatePathConfig.d.ts +1 -1
  297. package/lib/typescript/src/validatePathConfig.d.ts.map +1 -1
  298. package/lib/typescript/utils/usePrevious.d.ts +6 -0
  299. package/lib/typescript/utils/usePrevious.d.ts.map +1 -0
  300. package/package.json +14 -14
  301. package/src/BaseNavigationContainer.tsx +35 -36
  302. package/src/Group.tsx +1 -1
  303. package/src/PreventRemoveProvider.tsx +4 -1
  304. package/src/SceneView.tsx +1 -1
  305. package/src/Screen.tsx +1 -1
  306. package/src/StaticNavigation.tsx +34 -32
  307. package/src/checkDuplicateRouteNames.tsx +1 -1
  308. package/src/createNavigationContainerRef.tsx +1 -1
  309. package/src/createNavigatorFactory.tsx +2 -4
  310. package/src/getActionFromState.tsx +1 -1
  311. package/src/getFocusedRouteNameFromRoute.tsx +3 -3
  312. package/src/getPathFromState.tsx +20 -12
  313. package/src/getStateFromPath.tsx +80 -19
  314. package/src/index.tsx +6 -3
  315. package/src/theming/ThemeContext.tsx +7 -0
  316. package/src/theming/ThemeProvider.tsx +14 -0
  317. package/src/theming/useTheme.tsx +15 -0
  318. package/src/types.tsx +133 -17
  319. package/src/useDescriptors.tsx +153 -59
  320. package/src/useFocusEffect.tsx +1 -0
  321. package/src/useFocusedListenersChildrenAdapter.tsx +2 -2
  322. package/src/useIsomorphicLayoutEffect.native.tsx +3 -0
  323. package/src/useIsomorphicLayoutEffect.tsx +7 -0
  324. package/src/useNavigation.tsx +4 -1
  325. package/src/useNavigationBuilder.tsx +123 -100
  326. package/src/useNavigationCache.tsx +91 -30
  327. package/src/useNavigationContainerRef.tsx +1 -1
  328. package/src/useNavigationHelpers.tsx +6 -7
  329. package/src/useOnAction.tsx +8 -3
  330. package/src/useOnGetState.tsx +1 -1
  331. package/src/useOnPreventRemove.tsx +1 -1
  332. package/src/useOptionsGetters.tsx +2 -2
  333. package/src/usePreventRemove.tsx +1 -1
  334. package/src/useRouteCache.tsx +17 -16
  335. package/src/useSyncState.tsx +31 -59
  336. package/src/validatePathConfig.tsx +58 -14
  337. package/lib/commonjs/fromEntries.js +0 -18
  338. package/lib/commonjs/fromEntries.js.map +0 -1
  339. package/lib/commonjs/useScheduleUpdate.js +0 -37
  340. package/lib/commonjs/useScheduleUpdate.js.map +0 -1
  341. package/lib/module/fromEntries.js +0 -12
  342. package/lib/module/fromEntries.js.map +0 -1
  343. package/lib/module/useScheduleUpdate.js +0 -27
  344. package/lib/module/useScheduleUpdate.js.map +0 -1
  345. package/lib/typescript/src/fromEntries.d.ts +0 -2
  346. package/lib/typescript/src/fromEntries.d.ts.map +0 -1
  347. package/lib/typescript/src/useScheduleUpdate.d.ts +0 -14
  348. package/lib/typescript/src/useScheduleUpdate.d.ts.map +0 -1
  349. package/src/fromEntries.tsx +0 -11
  350. package/src/useScheduleUpdate.tsx +0 -32
@@ -11,6 +11,7 @@ import type { PathConfigMap } from './types';
11
11
  import { validatePathConfig } from './validatePathConfig';
12
12
 
13
13
  type Options<ParamList extends {}> = {
14
+ path?: string;
14
15
  initialRouteName?: string;
15
16
  screens: PathConfigMap<ParamList>;
16
17
  };
@@ -70,7 +71,7 @@ export function getStateFromPath<ParamList extends {}>(
70
71
  validatePathConfig(options);
71
72
  }
72
73
 
73
- let initialRoutes: InitialRouteConfig[] = [];
74
+ const initialRoutes: InitialRouteConfig[] = [];
74
75
 
75
76
  if (options?.initialRouteName) {
76
77
  initialRoutes.push({
@@ -89,6 +90,21 @@ export function getStateFromPath<ParamList extends {}>(
89
90
  // Make sure there is a trailing slash
90
91
  remaining = remaining.endsWith('/') ? remaining : `${remaining}/`;
91
92
 
93
+ const prefix = options?.path?.replace(/^\//, ''); // Remove extra leading slash
94
+
95
+ if (prefix) {
96
+ // Make sure there is a trailing slash
97
+ const normalizedPrefix = prefix.endsWith('/') ? prefix : `${prefix}/`;
98
+
99
+ // If the path doesn't start with the prefix, it's not a match
100
+ if (!remaining.startsWith(normalizedPrefix)) {
101
+ return undefined;
102
+ }
103
+
104
+ // Remove the prefix from the path
105
+ remaining = remaining.replace(normalizedPrefix, '');
106
+ }
107
+
92
108
  if (screens === undefined) {
93
109
  // When no config is specified, use the path segments as route names
94
110
  const routes = remaining
@@ -271,29 +287,71 @@ const matchAgainstConfigs = (remaining: string, configs: RouteConfig[]) => {
271
287
 
272
288
  // If our regex matches, we need to extract params from the path
273
289
  if (match) {
274
- const matchedParams = config.pattern
275
- ?.split('/')
276
- .filter((p) => p.startsWith(':'))
277
- .reduce<Record<string, any>>(
278
- (acc, p, i) =>
279
- Object.assign(acc, {
280
- // The param segments appear every second item starting from 2 in the regex match result
281
- [p]: match![(i + 1) * 2].replace(/\//, ''),
290
+ const matchResult = config.pattern?.split('/').reduce<{
291
+ pos: number; // Position of the current path param segment in the path (e.g in pattern `a/:b/:c`, `:a` is 0 and `:b` is 1)
292
+ matchedParams: Record<string, Record<string, string>>; // The extracted params
293
+ }>(
294
+ (acc, p, index) => {
295
+ if (!p.startsWith(':')) {
296
+ return acc;
297
+ }
298
+
299
+ // Path parameter so increment position for the segment
300
+ acc.pos += 1;
301
+
302
+ const decodedParamSegment = decodeURIComponent(
303
+ // The param segments appear every second item starting from 2 in the regex match result
304
+ match![(acc.pos + 1) * 2]
305
+ );
306
+
307
+ Object.assign(acc.matchedParams, {
308
+ [p]: Object.assign(acc.matchedParams[p] || {}, {
309
+ [index]: decodedParamSegment.replace(/\//, ''),
282
310
  }),
283
- {}
284
- );
311
+ });
312
+
313
+ return acc;
314
+ },
315
+ { pos: -1, matchedParams: {} }
316
+ );
317
+
318
+ const matchedParams = matchResult.matchedParams || {};
285
319
 
286
320
  routes = config.routeNames.map((name) => {
287
- const config = configs.find((c) => c.screen === name);
288
- const params = config?.path
321
+ const routeConfig = configs.find((c) => {
322
+ // Check matching name AND pattern in case same screen is used at different levels in config
323
+ return c.screen === name && config.pattern.startsWith(c.pattern);
324
+ });
325
+
326
+ // Normalize pattern to remove any leading, trailing slashes, duplicate slashes etc.
327
+ const normalizedPath = routeConfig?.path
328
+ .split('/')
329
+ .filter(Boolean)
330
+ .join('/');
331
+
332
+ // Get the number of segments in the initial pattern
333
+ const numInitialSegments = routeConfig?.pattern
334
+ // Extract the prefix from the pattern by removing the ending path pattern (e.g pattern=`a/b/c/d` and normalizedPath=`c/d` becomes `a/b`)
335
+ .replace(new RegExp(`${escape(normalizedPath!)}$`), '')
336
+ ?.split('/').length;
337
+
338
+ const params = normalizedPath
289
339
  ?.split('/')
290
- .filter((p) => p.startsWith(':'))
291
- .reduce<Record<string, any>>((acc, p) => {
292
- const value = matchedParams[p];
340
+ .reduce<Record<string, unknown>>((acc, p, index) => {
341
+ if (!p.startsWith(':')) {
342
+ return acc;
343
+ }
344
+
345
+ // Get the real index of the path parameter in the matched path
346
+ // by offsetting by the number of segments in the initial pattern
347
+ const offset = numInitialSegments ? numInitialSegments - 1 : 0;
348
+ const value = matchedParams[p]?.[index + offset];
293
349
 
294
350
  if (value) {
295
351
  const key = p.replace(/^:/, '').replace(/\?$/, '');
296
- acc[key] = config.parse?.[key] ? config.parse[key](value) : value;
352
+ acc[key] = routeConfig?.parse?.[key]
353
+ ? routeConfig.parse[key](value)
354
+ : value;
297
355
  }
298
356
 
299
357
  return acc;
@@ -507,7 +565,6 @@ const createNestedStateObject = (
507
565
  initialRoutes: InitialRouteConfig[],
508
566
  flatConfig?: RouteConfig[]
509
567
  ) => {
510
- let state: InitialState;
511
568
  let route = routes.shift() as ParsedRoute;
512
569
  const parentScreens: string[] = [];
513
570
 
@@ -515,7 +572,11 @@ const createNestedStateObject = (
515
572
 
516
573
  parentScreens.push(route.name);
517
574
 
518
- state = createStateObject(initialRoute, route, routes.length === 0);
575
+ const state: InitialState = createStateObject(
576
+ initialRoute,
577
+ route,
578
+ routes.length === 0
579
+ );
519
580
 
520
581
  if (routes.length > 0) {
521
582
  let nestedState = state;
package/src/index.tsx CHANGED
@@ -15,12 +15,15 @@ export { NavigationRouteContext } from './NavigationRouteContext';
15
15
  export { PreventRemoveContext } from './PreventRemoveContext';
16
16
  export { PreventRemoveProvider } from './PreventRemoveProvider';
17
17
  export {
18
+ createComponentForStaticNavigation,
19
+ createPathConfigForStaticNavigation,
18
20
  type StaticNavigation,
19
21
  type StaticParamList,
20
22
  type StaticScreenProps,
21
- createComponentForStaticNavigation,
22
- createPathConfigForStaticNavigation,
23
23
  } from './StaticNavigation';
24
+ export { ThemeContext } from './theming/ThemeContext';
25
+ export { ThemeProvider } from './theming/ThemeProvider';
26
+ export { useTheme } from './theming/useTheme';
24
27
  export * from './types';
25
28
  export { useFocusEffect } from './useFocusEffect';
26
29
  export { useIsFocused } from './useIsFocused';
@@ -29,7 +32,7 @@ export { useNavigationBuilder } from './useNavigationBuilder';
29
32
  export { useNavigationContainerRef } from './useNavigationContainerRef';
30
33
  export { useNavigationIndependentTree } from './useNavigationIndependentTree';
31
34
  export { useNavigationState } from './useNavigationState';
32
- export { UNSTABLE_usePreventRemove } from './usePreventRemove';
35
+ export { usePreventRemove } from './usePreventRemove';
33
36
  export { usePreventRemoveContext } from './usePreventRemoveContext';
34
37
  export { useRoute } from './useRoute';
35
38
  export { validatePathConfig } from './validatePathConfig';
@@ -0,0 +1,7 @@
1
+ import * as React from 'react';
2
+
3
+ export const ThemeContext = React.createContext<
4
+ ReactNavigation.Theme | undefined
5
+ >(undefined);
6
+
7
+ ThemeContext.displayName = 'ThemeContext';
@@ -0,0 +1,14 @@
1
+ import * as React from 'react';
2
+
3
+ import { ThemeContext } from './ThemeContext';
4
+
5
+ type Props = {
6
+ value: ReactNavigation.Theme | undefined;
7
+ children: React.ReactNode;
8
+ };
9
+
10
+ export function ThemeProvider({ value, children }: Props) {
11
+ return (
12
+ <ThemeContext.Provider value={value}>{children}</ThemeContext.Provider>
13
+ );
14
+ }
@@ -0,0 +1,15 @@
1
+ import * as React from 'react';
2
+
3
+ import { ThemeContext } from './ThemeContext';
4
+
5
+ export function useTheme() {
6
+ const theme = React.useContext(ThemeContext);
7
+
8
+ if (theme == null) {
9
+ throw new Error(
10
+ "Couldn't find a theme. Is your component inside NavigationContainer or does it have a theme?"
11
+ );
12
+ }
13
+
14
+ return theme;
15
+ }
package/src/types.tsx CHANGED
@@ -14,6 +14,9 @@ declare global {
14
14
  namespace ReactNavigation {
15
15
  // eslint-disable-next-line @typescript-eslint/no-empty-interface
16
16
  interface RootParamList {}
17
+
18
+ // eslint-disable-next-line @typescript-eslint/no-empty-interface
19
+ interface Theme {}
17
20
  }
18
21
  }
19
22
 
@@ -23,17 +26,44 @@ export type DefaultNavigatorOptions<
23
26
  ParamList extends ParamListBase,
24
27
  State extends NavigationState,
25
28
  ScreenOptions extends {},
26
- EventMap extends EventMapBase
29
+ EventMap extends EventMapBase,
27
30
  > = DefaultRouterOptions<Keyof<ParamList>> & {
28
31
  /**
29
32
  * Optional ID for the navigator. Can be used with `navigation.getParent(id)` to refer to a parent.
30
33
  */
31
34
  id?: string;
35
+
32
36
  /**
33
37
  * Children React Elements to extract the route configuration from.
34
38
  * Only `Screen`, `Group` and `React.Fragment` are supported as children.
35
39
  */
36
40
  children: React.ReactNode;
41
+
42
+ /**
43
+ * Layout for the navigator.
44
+ * Useful for wrapping with a component with access to navigator's state and options.
45
+ */
46
+ layout?: (props: {
47
+ state: State;
48
+ navigation: NavigationHelpers<ParamList>;
49
+ descriptors: Record<
50
+ string,
51
+ Descriptor<
52
+ ScreenOptions,
53
+ NavigationProp<
54
+ ParamList,
55
+ keyof ParamList,
56
+ string | undefined,
57
+ State,
58
+ ScreenOptions,
59
+ EventMap
60
+ >,
61
+ RouteProp<ParamList>
62
+ >
63
+ >;
64
+ children: React.ReactNode;
65
+ }) => React.ReactElement;
66
+
37
67
  /**
38
68
  * Event listeners for all the screens in the navigator.
39
69
  */
@@ -43,6 +73,7 @@ export type DefaultNavigatorOptions<
43
73
  route: RouteProp<ParamList>;
44
74
  navigation: any;
45
75
  }) => ScreenListeners<State, EventMap>);
76
+
46
77
  /**
47
78
  * Default options for all screens under this navigator.
48
79
  */
@@ -51,7 +82,25 @@ export type DefaultNavigatorOptions<
51
82
  | ((props: {
52
83
  route: RouteProp<ParamList>;
53
84
  navigation: any;
85
+ theme: ReactNavigation.Theme;
54
86
  }) => ScreenOptions);
87
+
88
+ /**
89
+ * Layout for all screens under this navigator.
90
+ */
91
+ screenLayout?: (props: {
92
+ route: RouteProp<ParamList, keyof ParamList>;
93
+ navigation: any;
94
+ theme: ReactNavigation.Theme;
95
+ children: React.ReactElement;
96
+ }) => React.ReactElement;
97
+
98
+ /**
99
+ A function returning a state, which may be set after modifying the routes name.
100
+ */
101
+ getStateForRouteNamesChange?: (
102
+ state: NavigationState
103
+ ) => PartialState<NavigationState> | undefined;
55
104
  };
56
105
 
57
106
  export type EventMapBase = Record<
@@ -69,7 +118,7 @@ export type EventMapCore<State extends NavigationState> = {
69
118
  export type EventArg<
70
119
  EventName extends string,
71
120
  CanPreventDefault extends boolean | undefined = false,
72
- Data = undefined
121
+ Data = undefined,
73
122
  > = {
74
123
  /**
75
124
  * Type of the event (e.g. `focus`, `blur`)
@@ -94,7 +143,7 @@ export type EventArg<
94
143
 
95
144
  export type EventListenerCallback<
96
145
  EventMap extends EventMapBase,
97
- EventName extends keyof EventMap
146
+ EventName extends keyof EventMap,
98
147
  > = (
99
148
  e: EventArg<
100
149
  Extract<EventName, string>,
@@ -162,7 +211,7 @@ export class PrivateValueStore<T extends [any, any, any]> {
162
211
 
163
212
  type NavigationHelpersCommon<
164
213
  ParamList extends ParamListBase,
165
- State extends NavigationState = NavigationState
214
+ State extends NavigationState = NavigationState,
166
215
  > = {
167
216
  /**
168
217
  * Dispatch an action or an update function to the router.
@@ -251,6 +300,22 @@ type NavigationHelpersCommon<
251
300
  : never
252
301
  ): void;
253
302
 
303
+ /**
304
+ * Preloads the route in current navigation tree.
305
+ *
306
+ * @param name Name of the route to navigate to.
307
+ * @param [params] Params object for the route.
308
+ */
309
+ preload<RouteName extends keyof ParamList>(
310
+ ...args: RouteName extends unknown
311
+ ? undefined extends ParamList[RouteName]
312
+ ?
313
+ | [screen: RouteName]
314
+ | [screen: RouteName, params: ParamList[RouteName]]
315
+ : [screen: RouteName, params: ParamList[RouteName]]
316
+ : never
317
+ ): void;
318
+
254
319
  /**
255
320
  * Reset the navigation state to the provided state.
256
321
  *
@@ -297,11 +362,18 @@ type NavigationHelpersCommon<
297
362
  * Note that this method doesn't re-render screen when the result changes. So don't use it in `render`.
298
363
  */
299
364
  getState(): State;
365
+ /**
366
+ * Schedules the given state to be used as navigation state when the list of screens defined in the navigator changes
367
+ * instead of automatically calculating the new state, e.g. due to conditional rendering or dynamically defining screens.
368
+ *
369
+ * @param state Navigation state object.
370
+ */
371
+ setStateForNextRouteNamesChange(state: PartialState<State> | State): void;
300
372
  } & PrivateValueStore<[ParamList, unknown, unknown]>;
301
373
 
302
374
  export type NavigationHelpers<
303
375
  ParamList extends ParamListBase,
304
- EventMap extends EventMapBase = {}
376
+ EventMap extends EventMapBase = {},
305
377
  > = NavigationHelpersCommon<ParamList> &
306
378
  EventEmitter<EventMap> & {
307
379
  /**
@@ -342,6 +414,10 @@ export type NavigationContainerProps = {
342
414
  * @deprecated Use nested navigation API instead
343
415
  */
344
416
  navigationInChildEnabled?: boolean;
417
+ /**
418
+ * Theme object for the UI elements.
419
+ */
420
+ theme?: ReactNavigation.Theme;
345
421
  /**
346
422
  * Children elements to render.
347
423
  */
@@ -354,7 +430,7 @@ export type NavigationProp<
354
430
  NavigatorID extends string | undefined = undefined,
355
431
  State extends NavigationState = NavigationState<ParamList>,
356
432
  ScreenOptions extends {} = {},
357
- EventMap extends EventMapBase = {}
433
+ EventMap extends EventMapBase = {},
358
434
  > = Omit<NavigationHelpersCommon<ParamList, State>, 'getParent'> & {
359
435
  /**
360
436
  * Returns the navigation prop from a parent navigator based on the ID.
@@ -389,12 +465,12 @@ export type NavigationProp<
389
465
 
390
466
  export type RouteProp<
391
467
  ParamList extends ParamListBase,
392
- RouteName extends keyof ParamList = Keyof<ParamList>
468
+ RouteName extends keyof ParamList = Keyof<ParamList>,
393
469
  > = Route<Extract<RouteName, string>, ParamList[RouteName]>;
394
470
 
395
471
  export type CompositeNavigationProp<
396
472
  A extends NavigationProp<ParamListBase, string, any, any, any>,
397
- B extends NavigationHelpersCommon<ParamListBase, any>
473
+ B extends NavigationHelpersCommon<ParamListBase, any>,
398
474
  > = Omit<A & B, keyof NavigationProp<any>> &
399
475
  NavigationProp<
400
476
  /**
@@ -442,7 +518,7 @@ export type CompositeScreenProps<
442
518
  },
443
519
  B extends {
444
520
  navigation: NavigationHelpersCommon<any, any>;
445
- }
521
+ },
446
522
  > = {
447
523
  navigation: CompositeNavigationProp<A['navigation'], B['navigation']>;
448
524
  route: A['route'];
@@ -451,7 +527,7 @@ export type CompositeScreenProps<
451
527
  export type Descriptor<
452
528
  ScreenOptions extends {},
453
529
  Navigation extends NavigationProp<any, any, any, any, any, any>,
454
- Route extends RouteProp<any, any>
530
+ Route extends RouteProp<any, any>,
455
531
  > = {
456
532
  /**
457
533
  * Render the component associated with this route.
@@ -476,7 +552,7 @@ export type Descriptor<
476
552
 
477
553
  export type ScreenListeners<
478
554
  State extends NavigationState,
479
- EventMap extends EventMapBase
555
+ EventMap extends EventMapBase,
480
556
  > = Partial<{
481
557
  [EventName in keyof (EventMap & EventMapCore<State>)]: EventListenerCallback<
482
558
  EventMap,
@@ -486,7 +562,7 @@ export type ScreenListeners<
486
562
 
487
563
  type ScreenComponentType<
488
564
  ParamList extends ParamListBase,
489
- RouteName extends keyof ParamList
565
+ RouteName extends keyof ParamList,
490
566
  > =
491
567
  | React.ComponentType<{
492
568
  route: RouteProp<ParamList, RouteName>;
@@ -496,7 +572,7 @@ type ScreenComponentType<
496
572
 
497
573
  export type RouteConfigComponent<
498
574
  ParamList extends ParamListBase,
499
- RouteName extends keyof ParamList
575
+ RouteName extends keyof ParamList,
500
576
  > =
501
577
  | {
502
578
  /**
@@ -531,7 +607,7 @@ export type RouteConfig<
531
607
  RouteName extends keyof ParamList,
532
608
  State extends NavigationState,
533
609
  ScreenOptions extends {},
534
- EventMap extends EventMapBase
610
+ EventMap extends EventMapBase,
535
611
  > = {
536
612
  /**
537
613
  * Optional key for this screen. This doesn't need to be unique.
@@ -553,6 +629,7 @@ export type RouteConfig<
553
629
  | ((props: {
554
630
  route: RouteProp<ParamList, RouteName>;
555
631
  navigation: any;
632
+ theme: ReactNavigation.Theme;
556
633
  }) => ScreenOptions);
557
634
 
558
635
  /**
@@ -565,6 +642,18 @@ export type RouteConfig<
565
642
  navigation: any;
566
643
  }) => ScreenListeners<State, EventMap>);
567
644
 
645
+ /**
646
+ * Layout for this screen.
647
+ * Useful for wrapping the screen with custom containers.
648
+ * e.g. for styling, error boundaries, suspense, etc.
649
+ */
650
+ layout?: (props: {
651
+ route: RouteProp<ParamList, keyof ParamList>;
652
+ navigation: any;
653
+ theme: ReactNavigation.Theme;
654
+ children: React.ReactElement;
655
+ }) => React.ReactElement;
656
+
568
657
  /**
569
658
  * Function to return an unique ID for this screen.
570
659
  * Receives an object with the route params.
@@ -585,7 +674,7 @@ export type RouteConfig<
585
674
 
586
675
  export type RouteGroupConfig<
587
676
  ParamList extends ParamListBase,
588
- ScreenOptions extends {}
677
+ ScreenOptions extends {},
589
678
  > = {
590
679
  /**
591
680
  * Optional key for the screens in this group.
@@ -601,7 +690,20 @@ export type RouteGroupConfig<
601
690
  | ((props: {
602
691
  route: RouteProp<ParamList, keyof ParamList>;
603
692
  navigation: any;
693
+ theme: ReactNavigation.Theme;
604
694
  }) => ScreenOptions);
695
+
696
+ /**
697
+ * Layout for the screens inside the group.
698
+ * This will override the `screenLayout` of parent group or navigator.
699
+ */
700
+ screenLayout?: (props: {
701
+ route: RouteProp<ParamList, keyof ParamList>;
702
+ navigation: any;
703
+ theme: ReactNavigation.Theme;
704
+ children: React.ReactElement;
705
+ }) => React.ReactElement;
706
+
605
707
  /**
606
708
  * Children React Elements to extract the route configuration from.
607
709
  * Only `Screen`, `Group` and `React.Fragment` are supported as children.
@@ -673,6 +775,14 @@ export type NavigationContainerRef<ParamList extends {}> =
673
775
  * Whether the navigation container is ready to handle actions.
674
776
  */
675
777
  isReady(): boolean;
778
+ /**
779
+ * Stub function for setOptions on navigation object for use with useNavigation.
780
+ */
781
+ setOptions(): never;
782
+ /**
783
+ * Stub function for getParent on navigation object for use with useNavigation.
784
+ */
785
+ getParent(): undefined;
676
786
  };
677
787
 
678
788
  export type NavigationContainerRefWithCurrent<ParamList extends {}> =
@@ -685,7 +795,7 @@ export type TypedNavigator<
685
795
  State extends NavigationState,
686
796
  ScreenOptions extends {},
687
797
  EventMap extends EventMapBase,
688
- Navigator extends React.ComponentType<any>
798
+ Navigator extends React.ComponentType<any>,
689
799
  > = {
690
800
  /**
691
801
  * Navigator component which manages the child screens.
@@ -779,12 +889,18 @@ export type PathConfig<ParamList extends {}> = {
779
889
  * Name of the initial route to use for the navigator when the path matches.
780
890
  */
781
891
  initialRouteName?: keyof ParamList;
892
+ /**
893
+ * A function returning a state, which may be set after modifying the routes name.
894
+ */
895
+ getStateForRouteNamesChange?: (
896
+ state: NavigationState
897
+ ) => PartialState<NavigationState> | undefined;
782
898
  };
783
899
 
784
900
  export type PathConfigMap<ParamList extends {}> = {
785
901
  [RouteName in keyof ParamList]?: NonNullable<
786
902
  ParamList[RouteName]
787
- > extends NavigatorScreenParams<infer T>
903
+ > extends NavigatorScreenParams<infer T extends {}>
788
904
  ? string | PathConfig<T>
789
905
  : string | Omit<PathConfig<{}>, 'screens' | 'initialRouteName'>;
790
906
  };