mirror of
https://github.com/RoboSats/robosats.git
synced 2025-01-05 22:10:10 +00:00
60 lines
1.7 KiB
JavaScript
60 lines
1.7 KiB
JavaScript
import React, { Component } from "react";
|
|
import ReactDOM from 'react-dom/client';
|
|
import HomePage from "./HomePage";
|
|
import { CssBaseline, IconButton , Link} from "@mui/material";
|
|
import { ThemeProvider, createTheme } from '@mui/material/styles';
|
|
import UnsafeAlert from "./UnsafeAlert";
|
|
import { LearnDialog } from "./Dialogs";
|
|
|
|
import { I18nextProvider } from "react-i18next";
|
|
import i18n from "./i18n";
|
|
|
|
//Icons
|
|
import DarkModeIcon from '@mui/icons-material/DarkMode';
|
|
import LightModeIcon from '@mui/icons-material/LightMode';
|
|
import SchoolIcon from '@mui/icons-material/School';
|
|
|
|
export default class App extends Component {
|
|
constructor(props) {
|
|
super(props);
|
|
this.state = {
|
|
dark: false,
|
|
openLearn: false,
|
|
}
|
|
}
|
|
|
|
lightTheme = createTheme({});
|
|
|
|
darkTheme = createTheme({
|
|
palette: {
|
|
mode: 'dark',
|
|
background: {
|
|
default: "#070707"
|
|
},
|
|
},
|
|
});
|
|
|
|
render() {
|
|
return (
|
|
<I18nextProvider i18n={i18n}>
|
|
<ThemeProvider theme={this.state.dark ? this.darkTheme : this.lightTheme}>
|
|
<CssBaseline/>
|
|
<LearnDialog open={this.state.openLearn} onClose={()=> this.setState({openLearn:false})}/>
|
|
<IconButton sx={{position:'fixed',right:'34px'}} onClick={()=> this.setState({openLearn:true})}><SchoolIcon/></IconButton>
|
|
<IconButton sx={{position:'fixed',right:'0px'}} onClick={()=>this.setState({dark:!this.state.dark})}>
|
|
{this.state.dark ? <LightModeIcon/>:<DarkModeIcon/>}
|
|
</IconButton>
|
|
<UnsafeAlert className="unsafeAlert"/>
|
|
<HomePage/>
|
|
</ThemeProvider>
|
|
</I18nextProvider>
|
|
);
|
|
}
|
|
}
|
|
|
|
const root = ReactDOM.createRoot(
|
|
document.getElementById("app")
|
|
);
|
|
|
|
root.render(<App />);
|