BaaS_Driver_Android_App/app/(tabs)/_layout.tsx

45 lines
1.2 KiB
TypeScript

import React, { useEffect } from "react";
import { Tabs } from "expo-router";
import { TAB_CONFIG } from "@/constants/config";
import { useSelector } from "react-redux";
import { RootState } from "@/store";
import { initSocket } from "@/services/socket";
export default function TabLayout() {
const { isLoggedIn } = useSelector((state: RootState) => state.auth);
if (!isLoggedIn) return null;
useEffect(() => {
initSocket();
}, [isLoggedIn]);
return (
<Tabs
screenOptions={{
tabBarStyle: {
backgroundColor: "#252A34",
borderTopLeftRadius: 12,
borderTopRightRadius: 12,
position: "absolute",
overflow: "hidden",
},
tabBarActiveTintColor: "#fff",
tabBarInactiveTintColor: "#aaa",
}}
>
{TAB_CONFIG.map(({ name, title, Icon, IconFilled }) => (
<Tabs.Screen
key={name}
name={name}
options={{
title,
tabBarIcon: ({ color, focused }) => {
const IconComponent = focused ? IconFilled : Icon;
return <IconComponent />;
},
}}
/>
))}
</Tabs>
);
}