import React, { Suspense, useState, useEffect } from 'react'; import ReactDOM from 'react-dom/client'; import Main from './basic/Main'; import { CssBaseline } from '@mui/material'; import { ThemeProvider, createTheme, Theme } from '@mui/material/styles'; import UnsafeAlert from './components/UnsafeAlert'; import TorConnection from './components/TorConnection'; import { I18nextProvider } from 'react-i18next'; import i18n from './i18n/Web'; import { systemClient } from './services/System'; import { Settings, defaultSettings } from './models'; const defaultTheme: Theme = createTheme({ palette: { mode: defaultSettings.mode, background: { default: defaultSettings.mode === 'dark' ? '#070707' : '#fff', }, }, typography: { fontSize: defaultSettings.fontSize }, }); const App = (): JSX.Element => { const [theme, setTheme] = useState(defaultTheme); const [settings, setSettings] = useState(defaultSettings); const updateTheme = function () { setTheme( createTheme({ palette: { mode: settings.mode, background: { default: settings.mode === 'dark' ? '#070707' : '#fff', }, }, typography: { fontSize: settings.fontSize }, }), ); }; useEffect(() => { updateTheme(); }, [settings.fontSize, settings.mode]); useEffect(() => { i18n.changeLanguage(settings.language); }, []); return (
); }; const loadApp = () => { if (systemClient.loading) { setTimeout(loadApp, 200); } else { const root = ReactDOM.createRoot(document.getElementById('app') ?? new HTMLElement()); root.render(); } }; loadApp();