-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathApp.js
executable file
·110 lines (100 loc) · 3.46 KB
/
App.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
import React from 'react';
import { useColorScheme } from 'react-native';
import {
adaptNavigationTheme,
PaperProvider,
} from 'react-native-paper';
import { SafeAreaProvider } from 'react-native-safe-area-context';
import {
createMaterialBottomTabNavigator,
} from '@react-navigation/material-bottom-tabs';
import {
DarkTheme as NavigationDarkTheme,
DefaultTheme as NavigationDefaultTheme,
NavigationContainer,
} from '@react-navigation/native';
import { createNativeStackNavigator } from '@react-navigation/native-stack';
import About from './pages/About';
import Chatroom from './pages/Chatroom';
import EditCharacter from './pages/EditCharacter';
import EditStickerSet from './pages/EditStickerSet';
import EditTTSService from './pages/EditTTSService';
import Home from './pages/Home';
import NewCharacter from './pages/NewCharacter';
import Settings from './pages/Settings';
import SignIn from './pages/SignIn';
import Sticker from './pages/Sticker';
import TTSService from './pages/TTSService';
import VoiceChat from './pages/VoiceChat';
import { mdTheme } from './shared/styles';
const { LightTheme, DarkTheme } = adaptNavigationTheme({
reactNavigationLight: NavigationDefaultTheme,
reactNavigationDark: NavigationDarkTheme
});
const Stack = createNativeStackNavigator()
const Tab = createMaterialBottomTabNavigator()
function MainPage({ }) {
return (
<Tab.Navigator>
<Tab.Screen name="Home" options={{
tabBarIcon: "home"
}} component={Home} />
<Tab.Screen name="Stickers" options={{
tabBarIcon: "sticker-emoji"
}} component={Sticker} />
<Tab.Screen name="TTS Services" options={{
tabBarIcon: "microphone"
}} component={TTSService} />
<Tab.Screen name="Settings" options={{
tabBarIcon: "cog"
}} component={Settings} />
</Tab.Navigator>
)
}
export default function App() {
const scheme = useColorScheme()
return (
<PaperProvider theme={mdTheme()}>
<SafeAreaProvider>
<NavigationContainer theme={scheme === 'dark' ? DarkTheme : LightTheme}>
<Stack.Navigator initialRouteName='MainPage'>
<Stack.Screen name="About" options={{ headerShown: false }} component={
About
}
/>
<Stack.Screen name="Sign In" options={{ headerShown: false, tabBarVisible: false }} component={
SignIn
}
/>
<Stack.Screen name="MainPage" options={{ headerShown: false }} component={
MainPage
}
/>
<Stack.Screen name="New Character" options={{ headerShown: false }} component={
NewCharacter
}
/>
<Stack.Screen name="Chatroom" options={{ headerShown: false }} component={
Chatroom
}
/>
<Stack.Screen name="Edit Sticker Set" options={{ headerShown: false }} component={
EditStickerSet
}
/>
<Stack.Screen name="Edit Character" options={{ headerShown: false }} component={
EditCharacter
}
/>
<Stack.Screen name="Edit TTS Service" options={{ headerShown: false }} component={
EditTTSService
}
/>
<Stack.Screen name="Voice Chat" options={{ headerShown: false }} component={VoiceChat}
/>
</Stack.Navigator>
</NavigationContainer>
</SafeAreaProvider>
</PaperProvider>
);
}