| 
									
										
										
										
											2024-04-24 12:12:47 +02:00
										 |  |  | /* | 
					
						
							|  |  |  | 	GoToSocial | 
					
						
							|  |  |  | 	Copyright (C) GoToSocial Authors admin@gotosocial.org | 
					
						
							|  |  |  | 	SPDX-License-Identifier: AGPL-3.0-or-later | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	This program is free software: you can redistribute it and/or modify | 
					
						
							|  |  |  | 	it under the terms of the GNU Affero General Public License as published by | 
					
						
							|  |  |  | 	the Free Software Foundation, either version 3 of the License, or | 
					
						
							|  |  |  | 	(at your option) any later version. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	This program is distributed in the hope that it will be useful, | 
					
						
							|  |  |  | 	but WITHOUT ANY WARRANTY; without even the implied warranty of | 
					
						
							|  |  |  | 	MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the | 
					
						
							|  |  |  | 	GNU Affero General Public License for more details. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	You should have received a copy of the GNU Affero General Public License | 
					
						
							|  |  |  | 	along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | 
					
						
							|  |  |  | */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2024-04-25 18:24:24 +02:00
										 |  |  | import React, { StrictMode, useMemo } from "react"; | 
					
						
							| 
									
										
										
										
											2024-04-24 12:12:47 +02:00
										 |  |  | import "./style.css"; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import { createRoot } from "react-dom/client"; | 
					
						
							|  |  |  | import { Provider } from "react-redux"; | 
					
						
							|  |  |  | import { PersistGate } from "redux-persist/integration/react"; | 
					
						
							|  |  |  | import { store, persistor } from "./redux/store"; | 
					
						
							|  |  |  | import { Authorization } from "./components/authorization"; | 
					
						
							|  |  |  | import Loading from "./components/loading"; | 
					
						
							|  |  |  | import { Account } from "./lib/types/account"; | 
					
						
							| 
									
										
										
										
											2024-06-03 11:20:53 +02:00
										 |  |  | import { BaseUrlContext, RoleContext, InstanceDebugContext } from "./lib/navigation/util"; | 
					
						
							| 
									
										
										
										
											2024-04-24 12:12:47 +02:00
										 |  |  | import { SidebarMenu } from "./lib/navigation/menu"; | 
					
						
							|  |  |  | import { Redirect, Route, Router } from "wouter"; | 
					
						
							| 
									
										
										
										
											2024-04-25 18:24:24 +02:00
										 |  |  | import AdminMenu from "./views/admin/menu"; | 
					
						
							|  |  |  | import ModerationMenu from "./views/moderation/menu"; | 
					
						
							|  |  |  | import UserMenu from "./views/user/menu"; | 
					
						
							|  |  |  | import UserRouter from "./views/user/router"; | 
					
						
							|  |  |  | import { ErrorBoundary } from "./lib/navigation/error"; | 
					
						
							|  |  |  | import ModerationRouter from "./views/moderation/router"; | 
					
						
							|  |  |  | import AdminRouter from "./views/admin/router"; | 
					
						
							| 
									
										
										
										
											2024-06-03 11:20:53 +02:00
										 |  |  | import { useInstanceV1Query } from "./lib/query/gts-api"; | 
					
						
							| 
									
										
										
										
											2024-04-24 12:12:47 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | interface AppProps { | 
					
						
							|  |  |  | 	account: Account; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | export function App({ account }: AppProps) { | 
					
						
							| 
									
										
										
										
											2024-04-25 18:24:24 +02:00
										 |  |  | 	const roles: string[] = useMemo(() => [ account.role.name ], [account]); | 
					
						
							| 
									
										
										
										
											2024-06-03 11:20:53 +02:00
										 |  |  | 	const { data: instance } = useInstanceV1Query(); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2024-04-24 12:12:47 +02:00
										 |  |  | 	return ( | 
					
						
							|  |  |  | 		<RoleContext.Provider value={roles}> | 
					
						
							| 
									
										
										
										
											2024-06-03 11:20:53 +02:00
										 |  |  | 			<InstanceDebugContext.Provider value={instance?.debug ?? false}> | 
					
						
							|  |  |  | 				<BaseUrlContext.Provider value={"/settings"}> | 
					
						
							|  |  |  | 					<SidebarMenu> | 
					
						
							|  |  |  | 						<UserMenu /> | 
					
						
							|  |  |  | 						<ModerationMenu /> | 
					
						
							|  |  |  | 						<AdminMenu /> | 
					
						
							|  |  |  | 					</SidebarMenu> | 
					
						
							|  |  |  | 					<section className="with-sidebar"> | 
					
						
							|  |  |  | 						<Router base="/settings"> | 
					
						
							|  |  |  | 							<ErrorBoundary> | 
					
						
							|  |  |  | 								<UserRouter /> | 
					
						
							|  |  |  | 								<ModerationRouter /> | 
					
						
							|  |  |  | 								<AdminRouter /> | 
					
						
							|  |  |  | 								{/* | 
					
						
							| 
									
										
										
										
											2024-05-01 15:11:22 +02:00
										 |  |  | 								Ensure user ends up somewhere | 
					
						
							|  |  |  | 								if they just open /settings. | 
					
						
							|  |  |  | 							*/} | 
					
						
							| 
									
										
										
										
											2024-06-03 11:20:53 +02:00
										 |  |  | 								<Route path="/"><Redirect to="/user" /></Route> | 
					
						
							|  |  |  | 							</ErrorBoundary> | 
					
						
							|  |  |  | 						</Router> | 
					
						
							|  |  |  | 					</section> | 
					
						
							|  |  |  | 				</BaseUrlContext.Provider> | 
					
						
							|  |  |  | 			</InstanceDebugContext.Provider> | 
					
						
							| 
									
										
										
										
											2024-04-24 12:12:47 +02:00
										 |  |  | 		</RoleContext.Provider> | 
					
						
							|  |  |  | 	); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function Main() { | 
					
						
							|  |  |  | 	return ( | 
					
						
							|  |  |  | 		<Provider store={store}> | 
					
						
							|  |  |  | 			<PersistGate | 
					
						
							|  |  |  | 				loading={<section><Loading /></section>} | 
					
						
							|  |  |  | 				persistor={persistor} | 
					
						
							|  |  |  | 			> | 
					
						
							|  |  |  | 				<Authorization App={App} /> | 
					
						
							|  |  |  | 			</PersistGate> | 
					
						
							|  |  |  | 		</Provider> | 
					
						
							|  |  |  | 	); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | const root = createRoot(document.getElementById("root") as HTMLElement); | 
					
						
							|  |  |  | root.render(<StrictMode><Main /></StrictMode>); |