14060c00aS猫头猫import React from 'react'; 2bf6e62f2S猫头猫import {NavigationContainer} from '@react-navigation/native'; 3bf6e62f2S猫头猫import {createNativeStackNavigator} from '@react-navigation/native-stack'; 4bf6e62f2S猫头猫import bootstrap from './bootstrap'; 503f1f70cS猫头猫import {RootStackParamList, routes} from './router'; 6bf6e62f2S猫头猫import {Provider as PaperProvider} from 'react-native-paper'; 7bf6e62f2S猫头猫import {GestureHandlerRootView} from 'react-native-gesture-handler'; 8bf6e62f2S猫头猫import Dialogs from '@/components/dialogs'; 9bf6e62f2S猫头猫import Toast from 'react-native-toast-message'; 10bf6e62f2S猫头猫import Panels from '@/components/panels'; 1108a8e62cS猫头猫import {CustomTheme, DefaultTheme} from './theme'; 12e22d5e4fS猫头猫import Config from '@/core/config'; 13d1f226e6S猫头猫import Share from '@/components/share'; 1419dc08ecS猫头猫import PageBackground from '@/components/base/pageBackground'; 151c06c799S猫头猫import {SafeAreaProvider} from 'react-native-safe-area-context'; 16*2a3194f5S猫头猫import toastConfig from '@/components/base/toast'; 17bf6e62f2S猫头猫 18bf6e62f2S猫头猫/** 19bf6e62f2S猫头猫 * 字体颜色 20bf6e62f2S猫头猫 */ 21bf6e62f2S猫头猫 22bf6e62f2S猫头猫bootstrap(); 2303f1f70cS猫头猫const Stack = createNativeStackNavigator<RootStackParamList>(); 24bf6e62f2S猫头猫 25bf6e62f2S猫头猫export default function Pages() { 26e22d5e4fS猫头猫 const themeName = Config.useConfig('setting.theme.mode') ?? 'dark'; 27e22d5e4fS猫头猫 const themeColors = Config.useConfig('setting.theme.colors') ?? {}; 28c7676810S猫头猫 const theme = themeName.includes('dark') ? CustomTheme : DefaultTheme; 29c7676810S猫头猫 const isCustom = themeName.includes('custom') ? true : false; 30c7676810S猫头猫 const mergedTheme = isCustom 31c7676810S猫头猫 ? { 320d39db21S猫头猫 ...theme, 330d39db21S猫头猫 colors: { 340d39db21S猫头猫 ...theme.colors, 350d39db21S猫头猫 ...themeColors, 360d39db21S猫头猫 }, 37c7676810S猫头猫 } 38c7676810S猫头猫 : theme; 39bf6e62f2S猫头猫 40bf6e62f2S猫头猫 return ( 41bf6e62f2S猫头猫 <GestureHandlerRootView style={{flex: 1}}> 420d39db21S猫头猫 <PaperProvider theme={mergedTheme}> 431c06c799S猫头猫 <SafeAreaProvider> 440d39db21S猫头猫 <NavigationContainer theme={mergedTheme}> 454060c00aS猫头猫 <PageBackground /> 46bf6e62f2S猫头猫 <Stack.Navigator 47bf6e62f2S猫头猫 initialRouteName={routes[0].path} 48bf6e62f2S猫头猫 screenOptions={{ 49bf6e62f2S猫头猫 statusBarColor: 'transparent', 50bf6e62f2S猫头猫 statusBarTranslucent: true, 51bf6e62f2S猫头猫 headerShown: false, 52bf6e62f2S猫头猫 animation: 'slide_from_right', 53bf6e62f2S猫头猫 animationDuration: 200, 54bf6e62f2S猫头猫 }}> 55bf6e62f2S猫头猫 {routes.map(route => ( 56bf6e62f2S猫头猫 <Stack.Screen 57bf6e62f2S猫头猫 key={route.path} 58bf6e62f2S猫头猫 name={route.path} 594060c00aS猫头猫 component={route.component} 604060c00aS猫头猫 /> 61bf6e62f2S猫头猫 ))} 62bf6e62f2S猫头猫 </Stack.Navigator> 63bf6e62f2S猫头猫 644060c00aS猫头猫 <Panels /> 654060c00aS猫头猫 <Dialogs /> 664060c00aS猫头猫 <Share /> 67*2a3194f5S猫头猫 <Toast config={toastConfig} /> 68bf6e62f2S猫头猫 </NavigationContainer> 691c06c799S猫头猫 </SafeAreaProvider> 70bf6e62f2S猫头猫 </PaperProvider> 71bf6e62f2S猫头猫 </GestureHandlerRootView> 72bf6e62f2S猫头猫 ); 73bf6e62f2S猫头猫} 74