79 lines
2.5 KiB
TypeScript
79 lines
2.5 KiB
TypeScript
import CssBaseline from '@material-ui/core/CssBaseline'
|
|
import { ThemeProvider } from '@material-ui/core/styles'
|
|
import { SnackbarProvider } from 'notistack'
|
|
import { ReactElement } from 'react'
|
|
import { HashRouter as Router } from 'react-router-dom'
|
|
import './App.css'
|
|
import Dashboard from './layout/Dashboard'
|
|
import { Provider as BeeProvider } from './providers/Bee'
|
|
import { Provider as FeedsProvider } from './providers/Feeds'
|
|
import { Provider as FileProvider } from './providers/File'
|
|
import { Provider as PlatformProvider } from './providers/Platform'
|
|
import { Provider as SettingsProvider } from './providers/Settings'
|
|
import { Provider as StampsProvider } from './providers/Stamps'
|
|
import { Provider as TopUpProvider } from './providers/TopUp'
|
|
import { Provider as BalanceProvider } from './providers/WalletBalance'
|
|
import BaseRouter from './routes'
|
|
import { theme } from './theme'
|
|
|
|
interface Props {
|
|
beeApiUrl?: string
|
|
defaultRpcUrl?: string
|
|
lockedApiSettings?: boolean
|
|
isDesktop?: boolean
|
|
desktopUrl?: string
|
|
errorReporting?: (err: Error) => void
|
|
}
|
|
|
|
const App = ({
|
|
beeApiUrl,
|
|
defaultRpcUrl,
|
|
lockedApiSettings,
|
|
isDesktop,
|
|
desktopUrl,
|
|
errorReporting,
|
|
}: Props): ReactElement => {
|
|
const mainApp = (
|
|
<div className="App">
|
|
<ThemeProvider theme={theme}>
|
|
<SettingsProvider
|
|
beeApiUrl={beeApiUrl}
|
|
defaultRpcUrl={defaultRpcUrl}
|
|
lockedApiSettings={lockedApiSettings}
|
|
isDesktop={isDesktop}
|
|
desktopUrl={desktopUrl}
|
|
>
|
|
<TopUpProvider>
|
|
<BeeProvider>
|
|
<BalanceProvider>
|
|
<StampsProvider>
|
|
<FileProvider>
|
|
<FeedsProvider>
|
|
<PlatformProvider>
|
|
<SnackbarProvider preventDuplicate anchorOrigin={{ horizontal: 'right', vertical: 'bottom' }}>
|
|
<Router>
|
|
<>
|
|
<CssBaseline />
|
|
<Dashboard errorReporting={errorReporting}>
|
|
<BaseRouter />
|
|
</Dashboard>
|
|
</>
|
|
</Router>
|
|
</SnackbarProvider>
|
|
</PlatformProvider>
|
|
</FeedsProvider>
|
|
</FileProvider>
|
|
</StampsProvider>
|
|
</BalanceProvider>
|
|
</BeeProvider>
|
|
</TopUpProvider>
|
|
</SettingsProvider>
|
|
</ThemeProvider>
|
|
</div>
|
|
)
|
|
|
|
return mainApp
|
|
}
|
|
|
|
export default App
|