@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.
- package/lib/commonjs/BaseNavigationContainer.js +25 -30
- package/lib/commonjs/BaseNavigationContainer.js.map +1 -1
- package/lib/commonjs/CurrentRenderContext.js +3 -4
- package/lib/commonjs/CurrentRenderContext.js.map +1 -1
- package/lib/commonjs/DeprecatedNavigationInChildContext.js +3 -4
- package/lib/commonjs/DeprecatedNavigationInChildContext.js.map +1 -1
- package/lib/commonjs/EnsureSingleNavigator.js +3 -4
- package/lib/commonjs/EnsureSingleNavigator.js.map +1 -1
- package/lib/commonjs/Group.js.map +1 -1
- package/lib/commonjs/NavigationBuilderContext.js +3 -4
- package/lib/commonjs/NavigationBuilderContext.js.map +1 -1
- package/lib/commonjs/NavigationContainerRefContext.js +3 -4
- package/lib/commonjs/NavigationContainerRefContext.js.map +1 -1
- package/lib/commonjs/NavigationContext.js +3 -4
- package/lib/commonjs/NavigationContext.js.map +1 -1
- package/lib/commonjs/NavigationHelpersContext.js +3 -4
- package/lib/commonjs/NavigationHelpersContext.js.map +1 -1
- package/lib/commonjs/NavigationIndependentTree.js +2 -2
- package/lib/commonjs/NavigationIndependentTree.js.map +1 -1
- package/lib/commonjs/NavigationIndependentTreeContext.js +3 -4
- package/lib/commonjs/NavigationIndependentTreeContext.js.map +1 -1
- package/lib/commonjs/NavigationRouteContext.js +3 -4
- package/lib/commonjs/NavigationRouteContext.js.map +1 -1
- package/lib/commonjs/NavigationStateContext.js +3 -4
- package/lib/commonjs/NavigationStateContext.js.map +1 -1
- package/lib/commonjs/PreventRemoveContext.js +8 -4
- package/lib/commonjs/PreventRemoveContext.js.map +1 -1
- package/lib/commonjs/PreventRemoveProvider.js +8 -10
- package/lib/commonjs/PreventRemoveProvider.js.map +1 -1
- package/lib/commonjs/SceneView.js +2 -2
- package/lib/commonjs/SceneView.js.map +1 -1
- package/lib/commonjs/Screen.js.map +1 -1
- package/lib/commonjs/StaticContainer.js +3 -4
- package/lib/commonjs/StaticContainer.js.map +1 -1
- package/lib/commonjs/StaticNavigation.js +34 -7
- package/lib/commonjs/StaticNavigation.js.map +1 -1
- package/lib/commonjs/UnhandledActionContext.js +3 -4
- package/lib/commonjs/UnhandledActionContext.js.map +1 -1
- package/lib/commonjs/checkDuplicateRouteNames.js +1 -2
- package/lib/commonjs/checkDuplicateRouteNames.js.map +1 -1
- package/lib/commonjs/checkSerializable.js.map +1 -1
- package/lib/commonjs/createNavigationContainerRef.js +1 -2
- package/lib/commonjs/createNavigationContainerRef.js.map +1 -1
- package/lib/commonjs/createNavigatorFactory.js +0 -3
- package/lib/commonjs/createNavigatorFactory.js.map +1 -1
- package/lib/commonjs/findFocusedRoute.js +2 -4
- package/lib/commonjs/findFocusedRoute.js.map +1 -1
- package/lib/commonjs/getActionFromState.js +6 -8
- package/lib/commonjs/getActionFromState.js.map +1 -1
- package/lib/commonjs/getFocusedRouteNameFromRoute.js +1 -1
- package/lib/commonjs/getFocusedRouteNameFromRoute.js.map +1 -1
- package/lib/commonjs/getPathFromState.js +25 -22
- package/lib/commonjs/getPathFromState.js.map +1 -1
- package/lib/commonjs/getStateFromPath.js +63 -21
- package/lib/commonjs/getStateFromPath.js.map +1 -1
- package/lib/commonjs/index.js +27 -3
- package/lib/commonjs/index.js.map +1 -1
- package/lib/commonjs/isArrayEqual.js.map +1 -1
- package/lib/commonjs/isRecordEqual.js.map +1 -1
- package/lib/commonjs/theming/ThemeContext.js +12 -0
- package/lib/commonjs/theming/ThemeContext.js.map +1 -0
- package/lib/commonjs/theming/ThemeProvider.js +20 -0
- package/lib/commonjs/theming/ThemeProvider.js.map +1 -0
- package/lib/commonjs/theming/useTheme.js +18 -0
- package/lib/commonjs/theming/useTheme.js.map +1 -0
- package/lib/commonjs/types.js.map +1 -1
- package/lib/commonjs/useChildListeners.js +2 -2
- package/lib/commonjs/useChildListeners.js.map +1 -1
- package/lib/commonjs/useComponent.js +2 -2
- package/lib/commonjs/useComponent.js.map +1 -1
- package/lib/commonjs/useCurrentRender.js +2 -2
- package/lib/commonjs/useCurrentRender.js.map +1 -1
- package/lib/commonjs/useDescriptors.js +83 -31
- package/lib/commonjs/useDescriptors.js.map +1 -1
- package/lib/commonjs/useEventEmitter.js +5 -6
- package/lib/commonjs/useEventEmitter.js.map +1 -1
- package/lib/commonjs/useFocusEffect.js +4 -2
- package/lib/commonjs/useFocusEffect.js.map +1 -1
- package/lib/commonjs/useFocusEvents.js +4 -4
- package/lib/commonjs/useFocusEvents.js.map +1 -1
- package/lib/commonjs/useFocusedListenersChildrenAdapter.js +3 -3
- package/lib/commonjs/useFocusedListenersChildrenAdapter.js.map +1 -1
- package/lib/commonjs/useIsFocused.js +5 -4
- package/lib/commonjs/useIsFocused.js.map +1 -1
- package/lib/commonjs/useIsomorphicLayoutEffect.js +12 -0
- package/lib/commonjs/useIsomorphicLayoutEffect.js.map +1 -0
- package/lib/commonjs/useIsomorphicLayoutEffect.native.js +9 -0
- package/lib/commonjs/useIsomorphicLayoutEffect.native.js.map +1 -0
- package/lib/commonjs/useKeyedChildListeners.js +2 -2
- package/lib/commonjs/useKeyedChildListeners.js.map +1 -1
- package/lib/commonjs/useNavigation.js +2 -2
- package/lib/commonjs/useNavigation.js.map +1 -1
- package/lib/commonjs/useNavigationBuilder.js +81 -68
- package/lib/commonjs/useNavigationBuilder.js.map +1 -1
- package/lib/commonjs/useNavigationCache.js +57 -16
- package/lib/commonjs/useNavigationCache.js.map +1 -1
- package/lib/commonjs/useNavigationContainerRef.js +2 -2
- package/lib/commonjs/useNavigationContainerRef.js.map +1 -1
- package/lib/commonjs/useNavigationHelpers.js +4 -5
- package/lib/commonjs/useNavigationHelpers.js.map +1 -1
- package/lib/commonjs/useNavigationIndependentTree.js +2 -2
- package/lib/commonjs/useNavigationIndependentTree.js.map +1 -1
- package/lib/commonjs/useNavigationState.js +2 -2
- package/lib/commonjs/useNavigationState.js.map +1 -1
- package/lib/commonjs/useOnAction.js +6 -4
- package/lib/commonjs/useOnAction.js.map +1 -1
- package/lib/commonjs/useOnGetState.js +4 -5
- package/lib/commonjs/useOnGetState.js.map +1 -1
- package/lib/commonjs/useOnPreventRemove.js +5 -6
- package/lib/commonjs/useOnPreventRemove.js.map +1 -1
- package/lib/commonjs/useOnRouteFocus.js +2 -2
- package/lib/commonjs/useOnRouteFocus.js.map +1 -1
- package/lib/commonjs/useOptionsGetters.js +9 -10
- package/lib/commonjs/useOptionsGetters.js.map +1 -1
- package/lib/commonjs/usePreventRemove.js +5 -5
- package/lib/commonjs/usePreventRemove.js.map +1 -1
- package/lib/commonjs/usePreventRemoveContext.js +2 -2
- package/lib/commonjs/usePreventRemoveContext.js.map +1 -1
- package/lib/commonjs/useRegisterNavigator.js +2 -2
- package/lib/commonjs/useRegisterNavigator.js.map +1 -1
- package/lib/commonjs/useRoute.js +2 -2
- package/lib/commonjs/useRoute.js.map +1 -1
- package/lib/commonjs/useRouteCache.js +19 -16
- package/lib/commonjs/useRouteCache.js.map +1 -1
- package/lib/commonjs/useSyncState.js +27 -56
- package/lib/commonjs/useSyncState.js.map +1 -1
- package/lib/commonjs/validatePathConfig.js +37 -10
- package/lib/commonjs/validatePathConfig.js.map +1 -1
- package/lib/module/BaseNavigationContainer.js +22 -26
- package/lib/module/BaseNavigationContainer.js.map +1 -1
- package/lib/module/CurrentRenderContext.js.map +1 -1
- package/lib/module/DeprecatedNavigationInChildContext.js.map +1 -1
- package/lib/module/EnsureSingleNavigator.js.map +1 -1
- package/lib/module/Group.js.map +1 -1
- package/lib/module/NavigationBuilderContext.js.map +1 -1
- package/lib/module/NavigationContainerRefContext.js.map +1 -1
- package/lib/module/NavigationContext.js.map +1 -1
- package/lib/module/NavigationHelpersContext.js.map +1 -1
- package/lib/module/NavigationIndependentTree.js.map +1 -1
- package/lib/module/NavigationIndependentTreeContext.js.map +1 -1
- package/lib/module/NavigationRouteContext.js.map +1 -1
- package/lib/module/NavigationStateContext.js.map +1 -1
- package/lib/module/PreventRemoveContext.js.map +1 -1
- package/lib/module/PreventRemoveProvider.js +6 -8
- package/lib/module/PreventRemoveProvider.js.map +1 -1
- package/lib/module/SceneView.js.map +1 -1
- package/lib/module/Screen.js.map +1 -1
- package/lib/module/StaticContainer.js.map +1 -1
- package/lib/module/StaticNavigation.js +27 -5
- package/lib/module/StaticNavigation.js.map +1 -1
- package/lib/module/UnhandledActionContext.js.map +1 -1
- package/lib/module/checkDuplicateRouteNames.js +1 -2
- package/lib/module/checkDuplicateRouteNames.js.map +1 -1
- package/lib/module/checkSerializable.js.map +1 -1
- package/lib/module/createNavigationContainerRef.js.map +1 -1
- package/lib/module/createNavigatorFactory.js +0 -3
- package/lib/module/createNavigatorFactory.js.map +1 -1
- package/lib/module/findFocusedRoute.js +2 -4
- package/lib/module/findFocusedRoute.js.map +1 -1
- package/lib/module/getActionFromState.js +6 -8
- package/lib/module/getActionFromState.js.map +1 -1
- package/lib/module/getFocusedRouteNameFromRoute.js +1 -1
- package/lib/module/getFocusedRouteNameFromRoute.js.map +1 -1
- package/lib/module/getPathFromState.js +23 -20
- package/lib/module/getPathFromState.js.map +1 -1
- package/lib/module/getStateFromPath.js +61 -19
- package/lib/module/getStateFromPath.js.map +1 -1
- package/lib/module/index.js +4 -1
- package/lib/module/index.js.map +1 -1
- package/lib/module/isArrayEqual.js.map +1 -1
- package/lib/module/isRecordEqual.js.map +1 -1
- package/lib/module/theming/ThemeContext.js +4 -0
- package/lib/module/theming/ThemeContext.js.map +1 -0
- package/lib/module/theming/ThemeProvider.js +12 -0
- package/lib/module/theming/ThemeProvider.js.map +1 -0
- package/lib/module/theming/useTheme.js +10 -0
- package/lib/module/theming/useTheme.js.map +1 -0
- package/lib/module/types.js.map +1 -1
- package/lib/module/useChildListeners.js.map +1 -1
- package/lib/module/useComponent.js.map +1 -1
- package/lib/module/useCurrentRender.js.map +1 -1
- package/lib/module/useDescriptors.js +81 -29
- package/lib/module/useDescriptors.js.map +1 -1
- package/lib/module/useEventEmitter.js +3 -4
- package/lib/module/useEventEmitter.js.map +1 -1
- package/lib/module/useFocusEffect.js +2 -0
- package/lib/module/useFocusEffect.js.map +1 -1
- package/lib/module/useFocusEvents.js +2 -2
- package/lib/module/useFocusEvents.js.map +1 -1
- package/lib/module/useFocusedListenersChildrenAdapter.js +1 -1
- package/lib/module/useFocusedListenersChildrenAdapter.js.map +1 -1
- package/lib/module/useIsFocused.js.map +1 -1
- package/lib/module/useIsomorphicLayoutEffect.js +7 -0
- package/lib/module/useIsomorphicLayoutEffect.js.map +1 -0
- package/lib/module/useIsomorphicLayoutEffect.native.js +3 -0
- package/lib/module/useIsomorphicLayoutEffect.native.js.map +1 -0
- package/lib/module/useKeyedChildListeners.js.map +1 -1
- package/lib/module/useNavigation.js.map +1 -1
- package/lib/module/useNavigationBuilder.js +78 -66
- package/lib/module/useNavigationBuilder.js.map +1 -1
- package/lib/module/useNavigationCache.js +55 -14
- package/lib/module/useNavigationCache.js.map +1 -1
- package/lib/module/useNavigationContainerRef.js.map +1 -1
- package/lib/module/useNavigationHelpers.js +2 -3
- package/lib/module/useNavigationHelpers.js.map +1 -1
- package/lib/module/useNavigationIndependentTree.js.map +1 -1
- package/lib/module/useNavigationState.js.map +1 -1
- package/lib/module/useOnAction.js +4 -2
- package/lib/module/useOnAction.js.map +1 -1
- package/lib/module/useOnGetState.js +2 -3
- package/lib/module/useOnGetState.js.map +1 -1
- package/lib/module/useOnPreventRemove.js +3 -4
- package/lib/module/useOnPreventRemove.js.map +1 -1
- package/lib/module/useOnRouteFocus.js.map +1 -1
- package/lib/module/useOptionsGetters.js +7 -8
- package/lib/module/useOptionsGetters.js.map +1 -1
- package/lib/module/usePreventRemove.js +2 -2
- package/lib/module/usePreventRemove.js.map +1 -1
- package/lib/module/usePreventRemoveContext.js.map +1 -1
- package/lib/module/useRegisterNavigator.js.map +1 -1
- package/lib/module/useRoute.js.map +1 -1
- package/lib/module/useRouteCache.js +16 -12
- package/lib/module/useRouteCache.js.map +1 -1
- package/lib/module/useSyncState.js +25 -54
- package/lib/module/useSyncState.js.map +1 -1
- package/lib/module/validatePathConfig.js +37 -10
- package/lib/module/validatePathConfig.js.map +1 -1
- package/lib/typescript/src/BaseNavigationContainer.d.ts +2 -1
- package/lib/typescript/src/BaseNavigationContainer.d.ts.map +1 -1
- package/lib/typescript/src/EnsureSingleNavigator.d.ts +1 -1
- package/lib/typescript/src/EnsureSingleNavigator.d.ts.map +1 -1
- package/lib/typescript/src/NavigationContext.d.ts +1 -17
- package/lib/typescript/src/NavigationContext.d.ts.map +1 -1
- package/lib/typescript/src/NavigationHelpersContext.d.ts +1 -1
- package/lib/typescript/src/NavigationHelpersContext.d.ts.map +1 -1
- package/lib/typescript/src/NavigationIndependentTree.d.ts +1 -1
- package/lib/typescript/src/NavigationIndependentTree.d.ts.map +1 -1
- package/lib/typescript/src/NavigationRouteContext.d.ts +1 -1
- package/lib/typescript/src/NavigationRouteContext.d.ts.map +1 -1
- package/lib/typescript/src/NavigationStateContext.d.ts +2 -18
- package/lib/typescript/src/NavigationStateContext.d.ts.map +1 -1
- package/lib/typescript/src/PreventRemoveProvider.d.ts +1 -1
- package/lib/typescript/src/PreventRemoveProvider.d.ts.map +1 -1
- package/lib/typescript/src/SceneView.d.ts +2 -2
- package/lib/typescript/src/SceneView.d.ts.map +1 -1
- package/lib/typescript/src/StaticNavigation.d.ts +12 -5
- package/lib/typescript/src/StaticNavigation.d.ts.map +1 -1
- package/lib/typescript/src/createNavigatorFactory.d.ts.map +1 -1
- package/lib/typescript/src/findFocusedRoute.d.ts +1 -9
- package/lib/typescript/src/findFocusedRoute.d.ts.map +1 -1
- package/lib/typescript/src/getPathFromState.d.ts +1 -0
- package/lib/typescript/src/getPathFromState.d.ts.map +1 -1
- package/lib/typescript/src/getStateFromPath.d.ts +1 -0
- package/lib/typescript/src/getStateFromPath.d.ts.map +1 -1
- package/lib/typescript/src/index.d.ts +5 -2
- package/lib/typescript/src/index.d.ts.map +1 -1
- package/lib/typescript/src/theming/ThemeContext.d.ts +3 -0
- package/lib/typescript/src/theming/ThemeContext.d.ts.map +1 -0
- package/lib/typescript/src/theming/ThemeProvider.d.ts +8 -0
- package/lib/typescript/src/theming/ThemeProvider.d.ts.map +1 -0
- package/lib/typescript/src/theming/useTheme.d.ts +2 -0
- package/lib/typescript/src/theming/useTheme.d.ts.map +1 -0
- package/lib/typescript/src/types.d.ts +80 -1
- package/lib/typescript/src/types.d.ts.map +1 -1
- package/lib/typescript/src/useComponent.d.ts +1 -1
- package/lib/typescript/src/useComponent.d.ts.map +1 -1
- package/lib/typescript/src/useDescriptors.d.ts +107 -59
- package/lib/typescript/src/useDescriptors.d.ts.map +1 -1
- package/lib/typescript/src/useFocusEffect.d.ts.map +1 -1
- package/lib/typescript/src/useFocusedListenersChildrenAdapter.d.ts +1 -1
- package/lib/typescript/src/useFocusedListenersChildrenAdapter.d.ts.map +1 -1
- package/lib/typescript/src/useIsomorphicLayoutEffect.d.ts +6 -0
- package/lib/typescript/src/useIsomorphicLayoutEffect.d.ts.map +1 -0
- package/lib/typescript/src/useIsomorphicLayoutEffect.native.d.ts +3 -0
- package/lib/typescript/src/useIsomorphicLayoutEffect.native.d.ts.map +1 -0
- package/lib/typescript/src/useNavigation.d.ts +4 -1
- package/lib/typescript/src/useNavigation.d.ts.map +1 -1
- package/lib/typescript/src/useNavigationBuilder.d.ts +99 -63
- package/lib/typescript/src/useNavigationBuilder.d.ts.map +1 -1
- package/lib/typescript/src/useNavigationCache.d.ts +53 -3
- package/lib/typescript/src/useNavigationCache.d.ts.map +1 -1
- package/lib/typescript/src/useNavigationHelpers.d.ts +25 -55
- package/lib/typescript/src/useNavigationHelpers.d.ts.map +1 -1
- package/lib/typescript/src/useOnAction.d.ts +1 -1
- package/lib/typescript/src/useOnAction.d.ts.map +1 -1
- package/lib/typescript/src/useOnGetState.d.ts +1 -1
- package/lib/typescript/src/useOnGetState.d.ts.map +1 -1
- package/lib/typescript/src/useOnPreventRemove.d.ts +1 -1
- package/lib/typescript/src/useOnPreventRemove.d.ts.map +1 -1
- package/lib/typescript/src/usePreventRemove.d.ts +1 -1
- package/lib/typescript/src/usePreventRemove.d.ts.map +1 -1
- package/lib/typescript/src/useRouteCache.d.ts +1 -1
- package/lib/typescript/src/useRouteCache.d.ts.map +1 -1
- package/lib/typescript/src/useSyncState.d.ts +1 -4
- package/lib/typescript/src/useSyncState.d.ts.map +1 -1
- package/lib/typescript/src/validatePathConfig.d.ts +1 -1
- package/lib/typescript/src/validatePathConfig.d.ts.map +1 -1
- package/lib/typescript/utils/usePrevious.d.ts +6 -0
- package/lib/typescript/utils/usePrevious.d.ts.map +1 -0
- package/package.json +14 -14
- package/src/BaseNavigationContainer.tsx +35 -36
- package/src/Group.tsx +1 -1
- package/src/PreventRemoveProvider.tsx +4 -1
- package/src/SceneView.tsx +1 -1
- package/src/Screen.tsx +1 -1
- package/src/StaticNavigation.tsx +34 -32
- package/src/checkDuplicateRouteNames.tsx +1 -1
- package/src/createNavigationContainerRef.tsx +1 -1
- package/src/createNavigatorFactory.tsx +2 -4
- package/src/getActionFromState.tsx +1 -1
- package/src/getFocusedRouteNameFromRoute.tsx +3 -3
- package/src/getPathFromState.tsx +20 -12
- package/src/getStateFromPath.tsx +80 -19
- package/src/index.tsx +6 -3
- package/src/theming/ThemeContext.tsx +7 -0
- package/src/theming/ThemeProvider.tsx +14 -0
- package/src/theming/useTheme.tsx +15 -0
- package/src/types.tsx +133 -17
- package/src/useDescriptors.tsx +153 -59
- package/src/useFocusEffect.tsx +1 -0
- package/src/useFocusedListenersChildrenAdapter.tsx +2 -2
- package/src/useIsomorphicLayoutEffect.native.tsx +3 -0
- package/src/useIsomorphicLayoutEffect.tsx +7 -0
- package/src/useNavigation.tsx +4 -1
- package/src/useNavigationBuilder.tsx +123 -100
- package/src/useNavigationCache.tsx +91 -30
- package/src/useNavigationContainerRef.tsx +1 -1
- package/src/useNavigationHelpers.tsx +6 -7
- package/src/useOnAction.tsx +8 -3
- package/src/useOnGetState.tsx +1 -1
- package/src/useOnPreventRemove.tsx +1 -1
- package/src/useOptionsGetters.tsx +2 -2
- package/src/usePreventRemove.tsx +1 -1
- package/src/useRouteCache.tsx +17 -16
- package/src/useSyncState.tsx +31 -59
- package/src/validatePathConfig.tsx +58 -14
- package/lib/commonjs/fromEntries.js +0 -18
- package/lib/commonjs/fromEntries.js.map +0 -1
- package/lib/commonjs/useScheduleUpdate.js +0 -37
- package/lib/commonjs/useScheduleUpdate.js.map +0 -1
- package/lib/module/fromEntries.js +0 -12
- package/lib/module/fromEntries.js.map +0 -1
- package/lib/module/useScheduleUpdate.js +0 -27
- package/lib/module/useScheduleUpdate.js.map +0 -1
- package/lib/typescript/src/fromEntries.d.ts +0 -2
- package/lib/typescript/src/fromEntries.d.ts.map +0 -1
- package/lib/typescript/src/useScheduleUpdate.d.ts +0 -14
- package/lib/typescript/src/useScheduleUpdate.d.ts.map +0 -1
- package/src/fromEntries.tsx +0 -11
- package/src/useScheduleUpdate.tsx +0 -32
package/src/getStateFromPath.tsx
CHANGED
|
@@ -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
|
-
|
|
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
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
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
|
|
288
|
-
|
|
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
|
-
.
|
|
291
|
-
|
|
292
|
-
|
|
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] =
|
|
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(
|
|
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 {
|
|
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,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
|
};
|