import { BrowserRouter } from 'react-router-dom'; import { useUserStore } from './store/user'; import { QueryClientProvider } from '@tanstack/react-query'; import { queryClient } from './api/cache'; import { TokenLoginContainer } from './components/TokenLoginContainer'; import React, { useRef } from 'react'; import { trpc, trpcClient } from './api/trpc'; import { useInjectWebsiteScript } from './hooks/useInjectWebsiteScript'; import { ConfigProvider, theme } from 'antd'; import { useColorSchema } from './store/settings'; import { RouterProvider, createRouter } from '@tanstack/react-router'; import { routeTree } from './routeTree.gen'; import { DefaultNotFound } from './components/DefaultNotFound'; import { TooltipProvider } from './components/ui/tooltip'; import { Toaster } from './components/ui/sonner'; import { DefaultError } from './components/DefaultError'; const router = createRouter({ routeTree, context: { userInfo: undefined, }, defaultNotFoundComponent: DefaultNotFound, defaultErrorComponent: DefaultError, }); // Register the router instance for type safety declare module '@tanstack/react-router' { interface Register { router: typeof router; } } const AppRouter: React.FC = React.memo(() => { const { info: userInfo } = useUserStore(); useInjectWebsiteScript(); return ( {/* Compatible with old routes */} ); }); AppRouter.displayName = 'AppRouter'; export const App: React.FC = React.memo(() => { const rootRef = useRef(null); const colorScheme = useColorSchema(); const algorithm = colorScheme === 'dark' ? theme.darkAlgorithm : theme.defaultAlgorithm; return (
rootRef.current!} >
); }); App.displayName = 'App';