Agent-skills-standard react-native-navigation-v6
Configure React Navigation 6+ stacks, tabs, and deep linking for React Native. Use when implementing React Navigation stacks, tabs, or deep linking in React Native. (triggers: **/*Navigation*.tsx, src/navigation/**, navigation, react-navigation, stack, tab, drawer, deep link)
install
source · Clone the upstream repo
git clone https://github.com/HoangNguyen0403/agent-skills-standard
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/HoangNguyen0403/agent-skills-standard "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/react-native/react-native-navigation-v6" ~/.claude/skills/hoangnguyen0403-agent-skills-standard-react-native-navigation-v6 && rm -rf "$T"
manifest:
skills/react-native/react-native-navigation-v6/SKILL.mdsource content
React Native Navigation
Priority: P0 (CRITICAL)
Use React Navigation (official solution).
Build Type-Safe Navigation Stacks
- Architecture: Use Native Stack (
) by default for native performance. Only use JS Stack for custom transitions.createNativeStackNavigator - Typing: Use
for screens.NativeStackScreenProps
for nested Navigators.CompositeScreenProps
See deep linking reference for typed param lists and stack navigator setup.
Configure Deep Linking
- Deep Linking: Use prefix arrays in
config. Validate Universal Links (iOS) and App Links (Android). Handle unrecognized paths with 404 screen.linking
See deep linking reference for linking configuration with prefix arrays and fallback screens.
Implement Auth Flow
- Auth/App split: Conditionally render Auth Stack vs App Stack in
. Clear navigation state after logout.NavigationContainer - Logic: Use Tab Navigators for bottom navigation. Drawer for side menus.
- Transitions: Native-like feel via
. Custompresentation: 'modal'
inheaderLeft/Right
.options - Data Flow: Use
for small IDs only. Use global state (Zustand/RTK) for complex data objects.route.params
Anti-Patterns
- No String Literals: Use typed params.
- No Navigation in Business Logic: Pass callbacks from screens.
- No Deep Nesting: Max 2-3 levels of navigators.
References
See references/deep-linking.md for typed param lists, Universal Links, Nested Navigators, and State Persistence.