import { DarkTheme, DefaultTheme, ThemeProvider } from '@react-navigation/native';
import { Stack, router, useRootNavigationState, useSegments } from 'expo-router';
import * as SplashScreen from 'expo-splash-screen';
import { StatusBar } from 'expo-status-bar';
import { useEffect, useRef } from 'react';
import 'react-native-reanimated';
import { StripeProvider } from '@stripe/stripe-react-native';
import { LoadingSpinner } from '@/components/ui/LoadingSpinner';
import { ToastProvider } from '@/components/ui/Toast';
import { AuthProvider, useAuth } from '@/contexts/AuthContext';
import { BeneficiaryProvider } from '@/contexts/BeneficiaryContext';
import { useColorScheme } from '@/hooks/use-color-scheme';
// Stripe publishable key (test mode) - must match backend STRIPE_PUBLISHABLE_KEY
const STRIPE_PUBLISHABLE_KEY = 'pk_test_51P3kdqP0gvUw6M9C7ixPQHqbPcvga4G5kAYx1h6QXQAt1psbrC2rrmOojW0fTeQzaxD1Q9RKS3zZ23MCvjjZpWLi00eCFWRHMk';
// Prevent auto-hide, ignore errors if splash not available
SplashScreen.preventAutoHideAsync().catch(() => {});
// Track if splash screen was hidden to prevent double-hiding
let splashHidden = false;
function RootLayoutNav() {
const colorScheme = useColorScheme();
const { isAuthenticated, isInitializing } = useAuth();
const segments = useSegments();
const navigationState = useRootNavigationState();
// Track if initial redirect was done
const hasInitialRedirect = useRef(false);
useEffect(() => {
// Wait for navigation to be ready
if (!navigationState?.key) {
return;
}
// Wait for INITIAL auth check to complete
if (isInitializing) {
return;
}
// Hide splash screen safely (only once)
if (!splashHidden) {
splashHidden = true;
SplashScreen.hideAsync().catch(() => {});
}
const inAuthGroup = segments[0] === '(auth)';
// INITIAL REDIRECT (only once after app starts):
// - If not authenticated and not in auth → go to login
if (!hasInitialRedirect.current) {
hasInitialRedirect.current = true;
if (!isAuthenticated && !inAuthGroup) {
router.replace('/(auth)/login');
return;
}
}
// If not authenticated, do NOTHING - let the auth screens handle their own navigation
}, [isAuthenticated, isInitializing, navigationState?.key]);
// IMPORTANT: isLoading NOT in deps - we don't want to react to loading state changes
// segments also not in deps - we don't want to react to navigation changes
if (isInitializing) {
return ;
}
return (
);
}
export default function RootLayout() {
return (
);
}