56 lines
1.6 KiB
TypeScript
56 lines
1.6 KiB
TypeScript
import { Tabs } from 'expo-router';
|
|
import React from 'react';
|
|
import { Platform } from 'react-native';
|
|
import { HapticTab } from '@/components/default/HapticTab';
|
|
import { IconSymbol } from '@/components/ui/IconSymbol';
|
|
import TabBarBackground from '@/components/ui/TabBarBackground';
|
|
import { Colors } from '@/constants/Colors';
|
|
import { useColorScheme } from '@/hooks/useColorScheme';
|
|
|
|
const TabLayout = () => {
|
|
const scheme = useColorScheme() ?? 'dark';
|
|
|
|
return (
|
|
<Tabs
|
|
screenOptions={{
|
|
tabBarActiveTintColor: Colors[scheme].tint,
|
|
headerShown: false,
|
|
headerStyle: {
|
|
backgroundColor: Colors[scheme].background,
|
|
},
|
|
tabBarButton: HapticTab,
|
|
tabBarBackground: TabBarBackground,
|
|
tabBarStyle: Platform.select({
|
|
ios: {
|
|
// Use a transparent background on iOS to show the blur effect
|
|
position: 'absolute',
|
|
},
|
|
default: {
|
|
backgroundColor: Colors[scheme].background,
|
|
borderTopColor: Colors[scheme].tint,
|
|
borderTopWidth: 1,
|
|
},
|
|
}),
|
|
}}
|
|
>
|
|
<Tabs.Screen
|
|
name='index'
|
|
options={{
|
|
title: 'Home',
|
|
tabBarIcon: ({ color }) =>
|
|
<IconSymbol size={28} name='house.fill' color={color} />,
|
|
}}
|
|
/>
|
|
<Tabs.Screen
|
|
name='settings'
|
|
options={{
|
|
title: 'Settings',
|
|
tabBarIcon: ({ color }) =>
|
|
<IconSymbol size={28} name='gearshape.fill' color={color} />,
|
|
}}
|
|
/>
|
|
</Tabs>
|
|
);
|
|
};
|
|
export default TabLayout;
|