blob: 5b6b71dbec9298ae6077d83bb59e99e8a93ce5e9 [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';
Misha Krieger-Raynauld20cf1c82022-11-23 20:26:50 -050026import WebRtcProvider from './contexts/WebRtcProvider';
simon3f5f3e72022-11-08 21:01:57 -050027import WebSocketProvider from './contexts/WebSocketProvider';
simonf929a362022-11-18 16:53:45 -050028import { RouteParams } from './hooks/useUrlParams';
29import NotificationManager from './managers/NotificationManager';
simon3f5f3e72022-11-08 21:01:57 -050030import AccountSettings from './pages/AccountSettings';
31import CallInterface from './pages/CallInterface';
idillon3470d072022-11-22 15:22:34 -050032import GeneralSettings from './pages/GeneralSettings';
simon3f5f3e72022-11-08 21:01:57 -050033import Messenger from './pages/Messenger';
Michelle Sepkap Sime6967fb92022-11-08 08:39:36 -050034import Setup from './pages/Setup';
35import SetupLogin from './pages/SetupLogin';
simon3f5f3e72022-11-08 21:01:57 -050036import Welcome from './pages/Welcome';
37import { ThemeDemonstrator } from './themes/ThemeDemonstrator';
simon3f5f3e72022-11-08 21:01:57 -050038
simonf929a362022-11-18 16:53:45 -050039export type ConversationRouteParams = RouteParams<{ conversationId: string }, Record<string, never>>;
simonff1cb352022-11-24 15:15:26 -050040
simonf929a362022-11-18 16:53:45 -050041export type AddContactRouteParams = RouteParams<{ contactId: string }, Record<string, never>>;
42
simonff1cb352022-11-24 15:15:26 -050043export type CallRouteParams = RouteParams<
44 { conversationId?: string },
45 { role?: CallRole },
46 {
47 isVideoOn?: boolean;
48 callStatus: CallStatus;
49 }
50>;
simon3f5f3e72022-11-08 21:01:57 -050051
52export const router = createBrowserRouter(
53 createRoutesFromElements(
Michelle Sepkap Sime6967fb92022-11-08 08:39:36 -050054 <Route path="/" element={<App />} loader={appLoader}>
simon3f5f3e72022-11-08 21:01:57 -050055 <Route path="login" element={<Welcome />} />
Michelle Sepkap Sime6967fb92022-11-08 08:39:36 -050056 <Route path="setup/login" element={<SetupLogin />} />
57 <Route path="setup" element={<Setup />} />
simon3f5f3e72022-11-08 21:01:57 -050058 <Route path="theme" element={<ThemeDemonstrator />} />
59 <Route
60 element={
61 <AuthProvider>
62 <WebSocketProvider>
simonf929a362022-11-18 16:53:45 -050063 <NotificationManager>
64 <Outlet />
65 </NotificationManager>
simon3f5f3e72022-11-08 21:01:57 -050066 </WebSocketProvider>
67 </AuthProvider>
68 }
69 >
simonf929a362022-11-18 16:53:45 -050070 <Route index element={<Messenger />} />
71 <Route path="conversation" element={<Messenger />}>
simonff1cb352022-11-24 15:15:26 -050072 {/* TODO: Remove this route. Adding a contact should not change the route, we should instead use an internal
73 state in the Messenger component
74 */}
75 <Route path="add-contact" element={<div></div>} />
simonf929a362022-11-18 16:53:45 -050076 <Route
77 path=":conversationId"
78 element={
79 <ConversationProvider>
80 <Outlet />
81 </ConversationProvider>
82 }
83 >
84 <Route index element={<ConversationView />} />
85 <Route
86 path="call"
87 element={
Misha Krieger-Raynauld20cf1c82022-11-23 20:26:50 -050088 <WebRtcProvider>
simonf929a362022-11-18 16:53:45 -050089 <CallProvider>
90 <CallInterface />
91 </CallProvider>
Misha Krieger-Raynauld20cf1c82022-11-23 20:26:50 -050092 </WebRtcProvider>
simonf929a362022-11-18 16:53:45 -050093 }
94 />
95 </Route>
96 </Route>
idillon3470d072022-11-22 15:22:34 -050097 <Route path="settings-account" element={<AccountSettings />} />
98 <Route path="settings-general" element={<GeneralSettings />} />
simon3f5f3e72022-11-08 21:01:57 -050099 <Route path="contacts" element={<ContactList />} />
simon3f5f3e72022-11-08 21:01:57 -0500100 </Route>
simon3f5f3e72022-11-08 21:01:57 -0500101 </Route>
102 )
103);