Add bar on top of pages
This commit is contained in:
parent
7201889c2a
commit
25a7b4da7b
@ -8,11 +8,15 @@ import TabBarBackground from '@/components/ui/TabBarBackground';
|
|||||||
import { lightTheme, darkTheme } from '@/constants/Colors';
|
import { lightTheme, darkTheme } from '@/constants/Colors';
|
||||||
import { SafeAreaView, useSafeAreaInsets } from 'react-native-safe-area-context';
|
import { SafeAreaView, useSafeAreaInsets } from 'react-native-safe-area-context';
|
||||||
import { ThemedView } from '@/components/ThemedView';
|
import { ThemedView } from '@/components/ThemedView';
|
||||||
|
import { IconButton } from 'react-native-paper';
|
||||||
|
import { useNavigation } from '@react-navigation/native';
|
||||||
|
import { ThemedText } from '@/components/ThemedText';
|
||||||
|
|
||||||
export default function TabLayout() {
|
export default function TabLayout() {
|
||||||
const colorScheme = useColorScheme();
|
const colorScheme = useColorScheme();
|
||||||
const theme = colorScheme === 'dark' ? darkTheme : lightTheme;
|
const theme = colorScheme === 'dark' ? darkTheme : lightTheme;
|
||||||
const insets = useSafeAreaInsets();
|
const insets = useSafeAreaInsets();
|
||||||
|
const navigation = useNavigation();
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<View style={{ flex: 1 }}>
|
<View style={{ flex: 1 }}>
|
||||||
@ -37,25 +41,48 @@ export default function TabLayout() {
|
|||||||
right: 0,
|
right: 0,
|
||||||
height: insets.bottom,
|
height: insets.bottom,
|
||||||
backgroundColor: theme.colors.primary, // Or any custom color
|
backgroundColor: theme.colors.primary, // Or any custom color
|
||||||
zIndex: 1000,
|
zIndex: 1,
|
||||||
}}
|
}}
|
||||||
/>
|
/>
|
||||||
|
|
||||||
<SafeAreaView style={{ flex: 1, paddingBottom: 5 }} edges={['top', 'left', 'right']}>
|
<SafeAreaView style={{ flex: 1, paddingBottom: 5 }} edges={['top', 'left', 'right']}>
|
||||||
<ThemedView style={{ flex: 1 }}>
|
<ThemedView style={{ flex: 1 }}>
|
||||||
|
<View style={{
|
||||||
|
backgroundColor: theme.colors.onPrimary,
|
||||||
|
position: 'absolute',
|
||||||
|
display: 'flex',
|
||||||
|
flexDirection: 'row',
|
||||||
|
alignItems: 'center',
|
||||||
|
justifyContent: 'space-between',
|
||||||
|
top: 20,
|
||||||
|
left: 20,
|
||||||
|
right: 20,
|
||||||
|
borderRadius: 12,
|
||||||
|
zIndex: 1000,
|
||||||
|
}}>
|
||||||
|
<IconButton icon="menu" size={24} onPress={() => {
|
||||||
|
navigation.dispatch({ type: 'OPEN_DRAWER' });
|
||||||
|
}} />
|
||||||
|
<ThemedText
|
||||||
|
style={{ fontSize: 15, color: theme.colors.primary, letterSpacing: 2, fontWeight: 'bold' }}
|
||||||
|
>JOURNEY</ThemedText>
|
||||||
|
<IconButton icon="magnify" size={24} onPress={() => {
|
||||||
|
console.log('Search pressed');
|
||||||
|
}} />
|
||||||
|
</View>
|
||||||
<Tabs
|
<Tabs
|
||||||
screenOptions={{
|
screenOptions={{
|
||||||
tabBarActiveTintColor: theme.colors.primary,
|
tabBarActiveTintColor: theme.colors.primary,
|
||||||
headerShown: false,
|
headerShown: false,
|
||||||
tabBarLabelPosition: 'below-icon',
|
tabBarLabelPosition: 'below-icon',
|
||||||
tabBarButton: HapticTab,
|
tabBarButton: HapticTab,
|
||||||
tabBarBackground: TabBarBackground,
|
|
||||||
tabBarStyle: Platform.select({
|
tabBarStyle: Platform.select({
|
||||||
ios: {
|
ios: {
|
||||||
// Use a transparent background on iOS to show the blur effect
|
// Use a transparent background on iOS to show the blur effect
|
||||||
position: 'absolute',
|
position: 'absolute',
|
||||||
},
|
},
|
||||||
default: {},
|
default: {
|
||||||
|
},
|
||||||
}),
|
}),
|
||||||
}}>
|
}}>
|
||||||
<Tabs.Screen
|
<Tabs.Screen
|
||||||
|
|||||||
@ -5,7 +5,7 @@ import { HelloWave } from '@/components/HelloWave';
|
|||||||
import ParallaxScrollView from '@/components/ParallaxScrollView';
|
import ParallaxScrollView from '@/components/ParallaxScrollView';
|
||||||
import { ThemedText } from '@/components/ThemedText';
|
import { ThemedText } from '@/components/ThemedText';
|
||||||
import { ThemedView } from '@/components/ThemedView';
|
import { ThemedView } from '@/components/ThemedView';
|
||||||
import { List, Text, useTheme } from 'react-native-paper';
|
import { FAB, IconButton, List, Text, useTheme } from 'react-native-paper';
|
||||||
import { useEffect, useState } from 'react';
|
import { useEffect, useState } from 'react';
|
||||||
import AsyncStorage from '@react-native-async-storage/async-storage';
|
import AsyncStorage from '@react-native-async-storage/async-storage';
|
||||||
import { DATA_DIRECTORY_URI_KEY } from '@/constants/Settings';
|
import { DATA_DIRECTORY_URI_KEY } from '@/constants/Settings';
|
||||||
@ -30,17 +30,15 @@ export default function HomeScreen() {
|
|||||||
|
|
||||||
const theme = useTheme();
|
const theme = useTheme();
|
||||||
|
|
||||||
return (
|
|
||||||
<ThemedView style={{ flex: 1, padding: 16 }}>
|
|
||||||
<ThemedText type="title">
|
|
||||||
My Journey
|
|
||||||
</ThemedText>
|
|
||||||
<ThemedText>{theme.colors.primary}</ThemedText>
|
|
||||||
</ThemedView>
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
const styles = StyleSheet.create({
|
const styles = StyleSheet.create({
|
||||||
|
fab: {
|
||||||
|
position: 'absolute',
|
||||||
|
margin: 16,
|
||||||
|
right: 0,
|
||||||
|
bottom: 0,
|
||||||
|
backgroundColor: theme.colors.primary, // Use your theme's primary color
|
||||||
|
},
|
||||||
stepContainer: {
|
stepContainer: {
|
||||||
gap: 8,
|
gap: 8,
|
||||||
marginBottom: 8,
|
marginBottom: 8,
|
||||||
@ -52,4 +50,25 @@ const styles = StyleSheet.create({
|
|||||||
left: 20,
|
left: 20,
|
||||||
position: 'absolute',
|
position: 'absolute',
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
return (
|
||||||
|
<ThemedView style={{ flex: 1, padding: 16 }}>
|
||||||
|
<View style={{
|
||||||
|
backgroundColor: theme.colors.primary,
|
||||||
|
position: 'absolute',
|
||||||
|
top: 0,
|
||||||
|
left: 0,
|
||||||
|
right: 0,
|
||||||
|
height: 100,
|
||||||
|
zIndex: 1000,
|
||||||
|
}} />
|
||||||
|
<ThemedText>Directory: {dataDirectoryUri} </ThemedText>
|
||||||
|
<FAB icon="plus" color={theme.colors.onPrimary} style={styles.fab} onPress={() => {
|
||||||
|
console.log('Add new journey');
|
||||||
|
}} />
|
||||||
|
</ThemedView>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user