subtracks/app/navigation/RootNavigator.tsx
austinried 52e95dc959 don't use i18n namespaces
there's no need to keep reloading different parts of the object we already cached
2022-04-16 18:06:06 +09:00

64 lines
1.9 KiB
TypeScript

import { withSuspense } from '@app/components/withSuspense'
import BottomTabNavigator from '@app/navigation/BottomTabNavigator'
import NowPlayingQueue from '@app/screens/NowPlayingQueue'
import NowPlayingView from '@app/screens/NowPlayingView'
import colors from '@app/styles/colors'
import font from '@app/styles/font'
import { DarkTheme, NavigationContainer } from '@react-navigation/native'
import React from 'react'
import { useTranslation } from 'react-i18next'
import { createNativeStackNavigator } from 'react-native-screens/native-stack'
const NowPlayingStack = createNativeStackNavigator()
const NowPlayingNavigator = withSuspense(() => {
const { t } = useTranslation()
return (
<NowPlayingStack.Navigator>
<NowPlayingStack.Screen name="main" component={NowPlayingView} options={{ headerShown: false }} />
<NowPlayingStack.Screen
name="queue"
component={NowPlayingQueue}
options={{
title: t('resources.queue.name'),
headerStyle: {
backgroundColor: colors.gradient.high,
},
headerTitleStyle: {
fontSize: 18,
fontFamily: font.semiBold,
color: colors.text.primary,
},
headerHideShadow: true,
headerTintColor: 'white',
}}
/>
</NowPlayingStack.Navigator>
)
})
const RootStack = createNativeStackNavigator()
const theme = { ...DarkTheme }
theme.colors.background = colors.gradient.high
const RootNavigator = () => (
<NavigationContainer
theme={theme}
linking={{
prefixes: ['trackplayer'],
}}>
<RootStack.Navigator
screenOptions={{
headerShown: false,
}}
initialRouteName="top">
<RootStack.Screen name="top" component={BottomTabNavigator} />
<RootStack.Screen name="now-playing" component={NowPlayingNavigator} />
</RootStack.Navigator>
</NavigationContainer>
)
export default RootNavigator