73 lines
1.8 KiB
TypeScript
73 lines
1.8 KiB
TypeScript
import { Tabs, useRouter, useSegments } from "expo-router";
|
|
import { Ionicons } from "@expo/vector-icons";
|
|
import { useAuth } from "@clerk/clerk-expo";
|
|
import { useEffect } from "react";
|
|
|
|
export default function TabLayout() {
|
|
const { isSignedIn, isLoaded } = useAuth();
|
|
const router = useRouter();
|
|
const segments = useSegments();
|
|
|
|
useEffect(() => {
|
|
if (!isLoaded) return;
|
|
|
|
const inAuthGroup = segments[0] === "(auth)";
|
|
|
|
if (!isSignedIn && !inAuthGroup) {
|
|
// Redirect to sign-in if not authenticated
|
|
router.replace("/(auth)/sign-in");
|
|
}
|
|
}, [isSignedIn, isLoaded, segments]);
|
|
|
|
if (!isLoaded || !isSignedIn) {
|
|
return null;
|
|
}
|
|
|
|
return (
|
|
<Tabs
|
|
screenOptions={{
|
|
tabBarActiveTintColor: "#2563eb",
|
|
tabBarInactiveTintColor: "#6b7280",
|
|
headerShown: true,
|
|
headerStyle: {
|
|
backgroundColor: "#fff",
|
|
},
|
|
headerTitleStyle: {
|
|
fontWeight: "600",
|
|
},
|
|
}}
|
|
>
|
|
<Tabs.Screen
|
|
name="index"
|
|
options={{
|
|
title: "Home",
|
|
headerTitle: "FitAI",
|
|
tabBarIcon: ({ color, size }) => (
|
|
<Ionicons name="home" size={size} color={color} />
|
|
),
|
|
}}
|
|
/>
|
|
<Tabs.Screen
|
|
name="attendance"
|
|
options={{
|
|
title: "Attendance",
|
|
headerTitle: "Attendance",
|
|
tabBarIcon: ({ color, size }) => (
|
|
<Ionicons name="calendar" size={size} color={color} />
|
|
),
|
|
}}
|
|
/>
|
|
<Tabs.Screen
|
|
name="profile"
|
|
options={{
|
|
title: "Profile",
|
|
headerTitle: "My Profile",
|
|
tabBarIcon: ({ color, size }) => (
|
|
<Ionicons name="person" size={size} color={color} />
|
|
),
|
|
}}
|
|
/>
|
|
</Tabs>
|
|
);
|
|
}
|