mirror of
https://github.com/mue/mue.git
synced 2026-06-13 03:58:49 +02:00
Co-authored-by: Alex Sparkes <turbomarshmello@gmail.com> Co-authored-by: Wessel Tip <discord@go2it.eu> Co-authored-by: Isaac Saunders <contact@eartharoid.me>
121 lines
5.8 KiB
JavaScript
121 lines
5.8 KiB
JavaScript
import React from 'react';
|
|
import Background from './components/widgets/Background';
|
|
import Clock from './components/widgets/Clock';
|
|
import Greeting from './components/widgets/Greeting';
|
|
import Quote from './components/widgets/Quote';
|
|
import Search from './components/widgets/Search';
|
|
import Navbar from './components/Navbar';
|
|
import SettingsFunctions from './modules/settingsFunctions';
|
|
import { ToastContainer } from 'react-toastify';
|
|
import Modal from 'react-modal';
|
|
import RoomIcon from '@material-ui/icons/Room';
|
|
|
|
// Modals are lazy loaded as a user won't use them every time they open a tab
|
|
const Settings = React.lazy(() => import('./components/modals/Settings'));
|
|
const Update = React.lazy(() => import('./components/modals/Update'));
|
|
const Marketplace = React.lazy(() => import('./components/modals/Marketplace'));
|
|
const Addons = React.lazy(() => import('./components/modals/Addons'));
|
|
const Welcome = React.lazy(() => import('./components/modals/Welcome'));
|
|
const renderLoader = () => <div></div>;
|
|
|
|
export default class App extends React.PureComponent {
|
|
constructor(props) {
|
|
super(props);
|
|
|
|
this.state = {
|
|
settingsModal: false,
|
|
updateModal: false,
|
|
marketplaceModal: false,
|
|
addonsModal: false,
|
|
quickAccessmodal: false,
|
|
welcomeModal: false
|
|
};
|
|
}
|
|
|
|
// Render all the components
|
|
render() {
|
|
if (!localStorage.getItem('firstRun')) SettingsFunctions.setDefaultSettings();
|
|
|
|
let modalClassList = 'Modal';
|
|
if (localStorage.getItem('darkTheme') === 'true') modalClassList = 'Modal dark';
|
|
|
|
let overlayClassList = 'Overlay';
|
|
if (localStorage.getItem('animations') === 'true') overlayClassList = 'Overlay modal-animation';
|
|
|
|
let language = require(`./translations/${localStorage.getItem('language')}.json`);
|
|
|
|
const theme = localStorage.getItem('theme');
|
|
if (theme) {
|
|
let style = document.createElement('link');
|
|
style.href = theme;
|
|
style.rel = 'stylesheet';
|
|
document.head.appendChild(style);
|
|
}
|
|
|
|
return (
|
|
<React.Fragment>
|
|
<Background/>
|
|
<ToastContainer className='toast' position='bottom-right' autoClose={2500} hideProgressBar={false} newestOnTop={true} closeOnClick rtl={false} pauseOnFocusLoss />
|
|
<div id='center'>
|
|
<Search language={language.search} />
|
|
<Navbar settingsModalOpen={() => this.setState({ settingsModal: true })} updateModalOpen={() => this.setState({ updateModal: true })} />
|
|
<Greeting language={language.greeting} />
|
|
<Clock/>
|
|
<Quote language={language.toasts}/>
|
|
<div className='credits'>
|
|
<h1 id='photographer'>{language.credit}</h1>
|
|
<div id='backgroundCredits' className='tooltip'>
|
|
<RoomIcon className='locationicon'/>
|
|
<span className='tooltiptext' id='location'/>
|
|
</div>
|
|
</div>
|
|
<React.Suspense fallback={renderLoader()}>
|
|
<Modal id={'modal'} onRequestClose={() => this.setState({ settingsModal: false })} isOpen={this.state.settingsModal} className={modalClassList} overlayClassName={overlayClassList} ariaHideApp={false}>
|
|
<Settings
|
|
language={language.settings}
|
|
modalLanguage={language.modals}
|
|
modalClose={() => this.setState({ settingsModal: false })}
|
|
setDefaultSettings={() => SettingsFunctions.setDefaultSettings()}
|
|
openMarketplace={() => this.setState({ marketplaceModal: true, settingsModal: false })}
|
|
openAddons={() => this.setState({ settingsModal: false, addonsModal: true })}
|
|
toastLanguage={language.toasts}
|
|
/>
|
|
</Modal>
|
|
<Modal onRequestClose={() => this.setState({ updateModal: false })} isOpen={this.state.updateModal} className={modalClassList} overlayClassName={overlayClassList} ariaHideApp={false}>
|
|
<Update
|
|
language={language.update}
|
|
modalClose={() => this.setState({ updateModal: false })}
|
|
/>
|
|
</Modal>
|
|
<Modal onRequestClose={() => this.setState({ marketplaceModal: false })} isOpen={this.state.marketplaceModal} className={modalClassList} overlayClassName='Overlay' ariaHideApp={false}>
|
|
<Marketplace
|
|
language={language.marketplace}
|
|
modalLanguage={language.modals}
|
|
modalClose={() => this.setState({ marketplaceModal: false })}
|
|
openSettings={() => this.setState({ marketplaceModal: false, settingsModal: true })}
|
|
openAddons={() => this.setState({ marketplaceModal: false, addonsModal: true })}
|
|
toastLanguage={language.toasts}
|
|
/>
|
|
</Modal>
|
|
<Modal onRequestClose={() => this.setState({ addonsModal: false })} isOpen={this.state.addonsModal} className={modalClassList} overlayClassName='Overlay' ariaHideApp={false}>
|
|
<Addons
|
|
language={language.addons}
|
|
modalLanguage={language.modals}
|
|
modalClose={() => this.setState({ addonsModal: false })}
|
|
openSettings={() => this.setState({ addonsModal: false, settingsModal: true })}
|
|
openMarketplace={() => this.setState({ addonsModal: false, marketplaceModal: true })}
|
|
toastLanguage={language.toasts}
|
|
/>
|
|
</Modal>
|
|
<Modal onRequestClose={() => this.setState({ welcomeModal: false })} isOpen={this.state.welcomeModal} className={modalClassList} overlayClassName='Overlay' ariaHideApp={false}>
|
|
<Welcome
|
|
modalClose={() => this.setState({ welcomeModal: false })}
|
|
/>
|
|
</Modal>
|
|
</React.Suspense>
|
|
</div>
|
|
</React.Fragment>
|
|
);
|
|
}
|
|
}
|