blob: 714adde4e46cd1499990e5bab7c4530f8c243aa5 [file] [log] [blame]
simon3f5f3e72022-11-08 21:01:57 -05001/*
2 * Copyright (C) 2022 Savoir-faire Linux Inc.
3 *
4 * This program is free software; you can redistribute it and/or modify
5 * it under the terms of the GNU Affero General Public License as
6 * published by the Free Software Foundation; either version 3 of the
7 * License, or (at your option) any later version.
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU Affero General Public License for more details.
13 *
14 * You should have received a copy of the GNU Affero General Public
15 * License along with this program. If not, see
16 * <https://www.gnu.org/licenses/>.
17 */
18import { createBrowserRouter, createRoutesFromElements, Outlet, Route } from 'react-router-dom';
19
Michelle Sepkap Sime6967fb92022-11-08 08:39:36 -050020import App, { appLoader } from './App';
simon3f5f3e72022-11-08 21:01:57 -050021import ContactList from './components/ContactList';
simonf929a362022-11-18 16:53:45 -050022import ConversationView from './components/ConversationView';
simon3f5f3e72022-11-08 21:01:57 -050023import AuthProvider from './contexts/AuthProvider';
simonff1cb352022-11-24 15:15:26 -050024import CallProvider, { CallRole, CallStatus } from './contexts/CallProvider';
simonf929a362022-11-18 16:53:45 -050025import ConversationProvider from './contexts/ConversationProvider';
simon21f7d9f2022-11-28 14:21:54 -050026import MessengerProvider from './contexts/MessengerProvider';
Misha Krieger-Raynauld20cf1c82022-11-23 20:26:50 -050027import WebRtcProvider from './contexts/WebRtcProvider';
simon3f5f3e72022-11-08 21:01:57 -050028import WebSocketProvider from './contexts/WebSocketProvider';
simonf929a362022-11-18 16:53:45 -050029import { RouteParams } from './hooks/useUrlParams';
30import NotificationManager from './managers/NotificationManager';
simon3f5f3e72022-11-08 21:01:57 -050031import AccountSettings from './pages/AccountSettings';
32import CallInterface from './pages/CallInterface';
idillon3470d072022-11-22 15:22:34 -050033import GeneralSettings from './pages/GeneralSettings';
simon3f5f3e72022-11-08 21:01:57 -050034import Messenger from './pages/Messenger';
Michelle Sepkap Sime6967fb92022-11-08 08:39:36 -050035import Setup from './pages/Setup';
36import SetupLogin from './pages/SetupLogin';
simon3f5f3e72022-11-08 21:01:57 -050037import Welcome from './pages/Welcome';
38import { ThemeDemonstrator } from './themes/ThemeDemonstrator';
simon3f5f3e72022-11-08 21:01:57 -050039
simon21f7d9f2022-11-28 14:21:54 -050040export type ConversationRouteParams = RouteParams<{ conversationId?: string }, Record<string, never>>;
simonf929a362022-11-18 16:53:45 -050041
simonff1cb352022-11-24 15:15:26 -050042export type CallRouteParams = RouteParams<
43 { conversationId?: string },
44 { role?: CallRole },
45 {
46 isVideoOn?: boolean;
47 callStatus: CallStatus;
48 }
49>;
simon3f5f3e72022-11-08 21:01:57 -050050
51export const router = createBrowserRouter(
52 createRoutesFromElements(
Michelle Sepkap Sime6967fb92022-11-08 08:39:36 -050053 <Route path="/" element={<App />} loader={appLoader}>
simon3f5f3e72022-11-08 21:01:57 -050054 <Route path="login" element={<Welcome />} />
Michelle Sepkap Sime6967fb92022-11-08 08:39:36 -050055 <Route path="setup/login" element={<SetupLogin />} />
56 <Route path="setup" element={<Setup />} />
simon3f5f3e72022-11-08 21:01:57 -050057 <Route path="theme" element={<ThemeDemonstrator />} />
58 <Route
59 element={
60 <AuthProvider>
61 <WebSocketProvider>
simonf929a362022-11-18 16:53:45 -050062 <NotificationManager>
63 <Outlet />
64 </NotificationManager>
simon3f5f3e72022-11-08 21:01:57 -050065 </WebSocketProvider>
66 </AuthProvider>
67 }
68 >
simon21f7d9f2022-11-28 14:21:54 -050069 <Route
70 element={
71 <MessengerProvider>
72 <Outlet />
73 </MessengerProvider>
74 }
75 >
76 <Route index element={<Messenger />} />
77 <Route path="conversation" element={<Messenger />} />
simonf929a362022-11-18 16:53:45 -050078 <Route
simon21f7d9f2022-11-28 14:21:54 -050079 path="conversation/:conversationId"
simonf929a362022-11-18 16:53:45 -050080 element={
simon21f7d9f2022-11-28 14:21:54 -050081 <Messenger>
82 <ConversationProvider>
83 <Outlet />
84 </ConversationProvider>
85 </Messenger>
simonf929a362022-11-18 16:53:45 -050086 }
87 >
88 <Route index element={<ConversationView />} />
89 <Route
90 path="call"
91 element={
Misha Krieger-Raynauld20cf1c82022-11-23 20:26:50 -050092 <WebRtcProvider>
simonf929a362022-11-18 16:53:45 -050093 <CallProvider>
94 <CallInterface />
95 </CallProvider>
Misha Krieger-Raynauld20cf1c82022-11-23 20:26:50 -050096 </WebRtcProvider>
simonf929a362022-11-18 16:53:45 -050097 }
98 />
99 </Route>
100 </Route>
idillon3470d072022-11-22 15:22:34 -0500101 <Route path="settings-account" element={<AccountSettings />} />
102 <Route path="settings-general" element={<GeneralSettings />} />
simon3f5f3e72022-11-08 21:01:57 -0500103 <Route path="contacts" element={<ContactList />} />
simon3f5f3e72022-11-08 21:01:57 -0500104 </Route>
simon3f5f3e72022-11-08 21:01:57 -0500105 </Route>
106 )
107);