89 lines
2.4 KiB
TypeScript
89 lines
2.4 KiB
TypeScript
import { Redirect, Tabs } from 'expo-router';
|
|
import { Home, Clock, Zap, CalendarIcon, Building } from 'lucide-react-native';
|
|
import { useContext } from 'react';
|
|
import { AuthContext } from '@/utils/authContext';
|
|
import {useSafeAreaInsets} from "react-native-safe-area-context";
|
|
|
|
export default function ProtectedLayout() {
|
|
const authState = useContext(AuthContext);
|
|
const insets = useSafeAreaInsets();
|
|
|
|
if (!authState.isReady) {
|
|
return null;
|
|
}
|
|
|
|
if (!authState.isAuthenticated) {
|
|
return <Redirect href="/login" />;
|
|
}
|
|
|
|
return (
|
|
<Tabs
|
|
screenOptions={{
|
|
headerShown: false,
|
|
tabBarStyle: {
|
|
backgroundColor: '#ffffff',
|
|
borderTopWidth: 1,
|
|
borderTopColor: '#f3f4f6',
|
|
height: 70 + insets.bottom,
|
|
paddingBottom: insets.bottom,
|
|
paddingTop: 10,
|
|
paddingHorizontal: 10,
|
|
},
|
|
tabBarActiveTintColor: '#099499',
|
|
tabBarInactiveTintColor: '#9ca3af',
|
|
tabBarLabelStyle: {
|
|
fontSize: 12,
|
|
fontWeight: '600',
|
|
marginTop: 4
|
|
}
|
|
}}
|
|
backBehavior='history'
|
|
>
|
|
<Tabs.Screen
|
|
name="index"
|
|
options={{
|
|
title: 'Home',
|
|
tabBarIcon: ({ color, size }) => <Home pointerEvents="none" color={color} size={24} />,
|
|
}}
|
|
/>
|
|
<Tabs.Screen
|
|
name="attendance/index"
|
|
options={{
|
|
title: 'Presenze',
|
|
tabBarIcon: ({ color, size }) => <Clock pointerEvents="none" color={color} size={24} />,
|
|
}}
|
|
/>
|
|
<Tabs.Screen
|
|
name="permits/index"
|
|
options={{
|
|
title: 'Permessi',
|
|
tabBarIcon: ({ color, size }) => <CalendarIcon pointerEvents="none" color={color} size={24} />,
|
|
}}
|
|
/>
|
|
<Tabs.Screen
|
|
name="sites"
|
|
options={{
|
|
title: 'Cantieri',
|
|
tabBarIcon: ({ color, size }) => <Building pointerEvents="none" color={color} size={24} />,
|
|
}}
|
|
/>
|
|
{/* // TODO: Probably needs to be restricted to admin */}
|
|
<Tabs.Screen
|
|
name="automation"
|
|
options={{
|
|
title: 'Domotica',
|
|
tabBarIcon: ({ color, size }) => <Zap pointerEvents="none" color={color} size={24} />,
|
|
}}
|
|
/>
|
|
{/* TODO: Should be removed - move tabs inside (tabs) and refactor _layout */}
|
|
<Tabs.Screen
|
|
name="profile"
|
|
options={{
|
|
href: null,
|
|
title: 'Profilo',
|
|
}}
|
|
/>
|
|
</Tabs>
|
|
);
|
|
}
|