forked from agamsps/react-native-socket.io-chat
-
Notifications
You must be signed in to change notification settings - Fork 0
/
App.js
61 lines (49 loc) · 1.51 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
import React, { useCallback, useState } from 'react';
import { createNativeStackNavigator } from '@react-navigation/native-stack'
import { NavigationContainer } from '@react-navigation/native'
import ChatRoom from './src/chatroom';
import Login from './src/Login';
import Home from './src/pages';
import ParticularMessage from './src/MessageList';
import {
Chat,
OverlayProvider
} from 'stream-chat-react-native';
import { AppContext } from './src/context/AppContext';
import { chatClient } from './src/client';
const Stack = createNativeStackNavigator()
const App = () => {
const [channel, setChannel] = useState({
channel: {}
});
const DashboardStack = () => {
return (
<AppContext.Provider
value={{ channel: channel, setChannel }}>
<OverlayProvider>
<Chat client={chatClient}>
<Stack.Navigator
screenOptions={{
headerShown: false
}}>
<Stack.Screen name='Chats' component={ChatRoom} />
<Stack.Screen name='Message' component={ParticularMessage} />
</Stack.Navigator>
</Chat>
</OverlayProvider>
</AppContext.Provider>
)
}
return (
<NavigationContainer>
<Stack.Navigator
screenOptions={{
headerShown: false
}}>
<Stack.Screen name='Login' component={Login} />
<Stack.Screen name="DashboardStack" component={DashboardStack} />
</Stack.Navigator>
</NavigationContainer>
)
}
export default App