auth with handler

This commit is contained in:
tuanvu
2025-12-14 01:58:02 +01:00
parent 1f698076df
commit 0de6462c31
3 changed files with 65 additions and 50 deletions

View File

@@ -1,33 +1,27 @@
import { createBottomTabNavigator } from '@react-navigation/bottom-tabs';
import { } from 'expo-router';
import { Tabs } from 'expo-router';
import React from 'react';
import { HapticTab } from '@/components/expoExempleComponents/haptic-tab';
import { IconSymbol } from '@/components/ui/icon-symbol';
import { Colors } from '@/constants/theme';
import { useColorScheme } from '@/hooks/use-color-scheme';
import GestionOuvrier from './gestion_ouvrier';
import ListMateriel from './gestionnaire_ressource';
import Home from './home';
import MapScreen from './mapScreen';
import AntDesign from '@expo/vector-icons/AntDesign';
import AddScreen from './addScreen';
const Tabs = createBottomTabNavigator();
import { useUser } from '../ContextUser';
import { useAuthHandler } from '../AuthHandler';
export default function TabLayout() {
const colorScheme = useColorScheme();
const { role } = useUser();
// Handle auth in tabs layout
useAuthHandler();
return (
<Tabs.Navigator
initialRouteName='explore'
screenOptions={{
tabBarActiveTintColor: Colors[colorScheme ?? 'light'].tint,
headerShown: false,
tabBarButton: HapticTab,
}}>
<Tabs screenOptions={{tabBarActiveTintColor: Colors[colorScheme ?? 'light'].tint, headerShown: false, tabBarButton: HapticTab}}>
<Tabs.Screen name="index" options={{ href: null}}/>
<Tabs.Screen name="explore" options={{ href: null }}/>
<Tabs.Screen name="templateSreen" options={{ href: null}}/>
<Tabs.Screen
name="home"
component={Home}
options={{
title: 'Home',
tabBarIcon: ({ color }) => (
@@ -37,7 +31,6 @@ export default function TabLayout() {
/>
<Tabs.Screen
name="gestionnaire_ressource"
component={ListMateriel}
options={{
title: 'Ressources',
tabBarIcon: ({ color }) => (
@@ -46,34 +39,29 @@ export default function TabLayout() {
}}
/>
<Tabs.Screen
name="GestionOuvrier"
component={GestionOuvrier}
name="gestion_ouvrier"
options={{
title: 'Ouvriers',
tabBarIcon: ({ color }) => <IconSymbol size={28} name="person.fill" color={color} />,
}}
/>
<Tabs.Screen
name="explore"
component={MapScreen}
name="mapScreen"
options={{
title: 'MapScreen',
title: 'Map',
tabBarIcon: ({ color }) => <IconSymbol size={28} name="paperplane.fill" color={color} />,
}}
>
</Tabs.Screen>
/>
<Tabs.Screen
name="Ajouter"
component={AddScreen}
name="addScreen"
options={{
title: 'Ajouter',
href: role === 'chef' ? '/(tabs)/addScreen' : null,
tabBarIcon: ({ color }) => (
<AntDesign name="plus" size={24} color={color} />
),
}}
/>
</Tabs.Navigator>
</Tabs>
);
}
}