mirror of
https://github.com/Suwayomi/Tachidesk.git
synced 2026-02-01 16:34:13 +01:00
175 lines
7.1 KiB
TypeScript
175 lines
7.1 KiB
TypeScript
/*
|
|
* Copyright (C) Contributors to the Suwayomi project
|
|
*
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at https://mozilla.org/MPL/2.0/. */
|
|
|
|
import React, { useState } from 'react';
|
|
import {
|
|
BrowserRouter as Router, Switch,
|
|
Route,
|
|
Redirect,
|
|
} from 'react-router-dom';
|
|
import { Container } from '@material-ui/core';
|
|
import CssBaseline from '@material-ui/core/CssBaseline';
|
|
import { createMuiTheme, ThemeProvider } from '@material-ui/core/styles';
|
|
import NavBar from 'components/navbar/NavBar';
|
|
import NavbarContext from 'context/NavbarContext';
|
|
import DarkTheme from 'context/DarkTheme';
|
|
import useLocalStorage from 'util/useLocalStorage';
|
|
import MangaSources from 'screens/manga/MangaSources';
|
|
import AnimeSources from 'screens/anime/AnimeSources';
|
|
import Settings from 'screens/Settings';
|
|
import About from 'screens/settings/About';
|
|
import Categories from 'screens/settings/Categories';
|
|
import Backup from 'screens/settings/Backup';
|
|
import Library from 'screens/manga/Library';
|
|
import SearchSingle from 'screens/manga/SearchSingle';
|
|
import Manga from 'screens/manga/Manga';
|
|
import Anime from 'screens/anime/Anime';
|
|
import MangaExtensions from 'screens/manga/MangaExtensions';
|
|
import SourceMangas from 'screens/manga/SourceMangas';
|
|
import SourceAnimes from 'screens/anime/SourceAnimes';
|
|
import Reader from 'screens/manga/Reader';
|
|
import Player from 'screens/anime/Player';
|
|
import AnimeExtensions from 'screens/anime/AnimeExtensions';
|
|
import DownloadQueue from 'screens/manga/DownloadQueue';
|
|
|
|
export default function App() {
|
|
const [title, setTitle] = useState<string>('Tachidesk');
|
|
const [action, setAction] = useState<any>(<div />);
|
|
const [override, setOverride] = useState<INavbarOverride>({ status: false, value: <div /> });
|
|
|
|
const [darkTheme, setDarkTheme] = useLocalStorage<boolean>('darkTheme', true);
|
|
|
|
const navBarContext = {
|
|
title, setTitle, action, setAction, override, setOverride,
|
|
};
|
|
const darkThemeContext = { darkTheme, setDarkTheme };
|
|
|
|
const theme = React.useMemo(
|
|
() => createMuiTheme({
|
|
palette: {
|
|
type: darkTheme ? 'dark' : 'light',
|
|
},
|
|
overrides: {
|
|
MuiCssBaseline: {
|
|
'@global': {
|
|
'*::-webkit-scrollbar': {
|
|
width: '10px',
|
|
background: darkTheme ? '#222' : '#e1e1e1',
|
|
|
|
},
|
|
'*::-webkit-scrollbar-thumb': {
|
|
background: darkTheme ? '#111' : '#aaa',
|
|
borderRadius: '5px',
|
|
},
|
|
},
|
|
},
|
|
},
|
|
}),
|
|
[darkTheme],
|
|
);
|
|
|
|
return (
|
|
<Router>
|
|
<ThemeProvider theme={theme}>
|
|
<NavbarContext.Provider value={navBarContext}>
|
|
<CssBaseline />
|
|
<NavBar />
|
|
<Container
|
|
id="appMainContainer"
|
|
maxWidth={false}
|
|
disableGutters
|
|
style={{ paddingTop: '64px' }}
|
|
>
|
|
<Switch>
|
|
{/* general routes */}
|
|
<Route
|
|
exact
|
|
path="/"
|
|
render={() => (
|
|
<Redirect to="/library" />
|
|
)}
|
|
/>
|
|
|
|
<Route path="/settings/about">
|
|
<About />
|
|
</Route>
|
|
<Route path="/settings/categories">
|
|
<Categories />
|
|
</Route>
|
|
<Route path="/settings/backup">
|
|
<Backup />
|
|
</Route>
|
|
<Route path="/settings">
|
|
<DarkTheme.Provider value={darkThemeContext}>
|
|
<Settings />
|
|
</DarkTheme.Provider>
|
|
</Route>
|
|
|
|
{/* Manga Routes */}
|
|
|
|
<Route path="/sources/:sourceId/search/">
|
|
<SearchSingle />
|
|
</Route>
|
|
<Route path="/manga/extensions">
|
|
<MangaExtensions />
|
|
</Route>
|
|
<Route path="/sources/:sourceId/popular/">
|
|
<SourceMangas popular />
|
|
</Route>
|
|
<Route path="/sources/:sourceId/latest/">
|
|
<SourceMangas popular={false} />
|
|
</Route>
|
|
<Route path="/manga/sources">
|
|
<MangaSources />
|
|
</Route>
|
|
<Route path="/manga/downloads">
|
|
<DownloadQueue />
|
|
</Route>
|
|
<Route path="/manga/:mangaId/chapter/:chapterNum">
|
|
<></>
|
|
</Route>
|
|
<Route path="/manga/:id">
|
|
<Manga />
|
|
</Route>
|
|
<Route path="/library">
|
|
<Library />
|
|
</Route>
|
|
|
|
{/* Anime Routes */}
|
|
<Route path="/anime/extensions">
|
|
<AnimeExtensions />
|
|
</Route>
|
|
<Route path="/anime/sources/:sourceId/popular/">
|
|
<SourceAnimes popular />
|
|
</Route>
|
|
<Route path="/anime/sources/:sourceId/latest/">
|
|
<SourceMangas popular={false} />
|
|
</Route>
|
|
<Route path="/anime/sources">
|
|
<AnimeSources />
|
|
</Route>
|
|
<Route path="/anime/:animeId/episode/:episodeIndex">
|
|
<Player />
|
|
</Route>
|
|
<Route path="/anime/:id">
|
|
<Anime />
|
|
</Route>
|
|
</Switch>
|
|
</Container>
|
|
<Switch>
|
|
<Route
|
|
path="/manga/:mangaId/chapter/:chapterIndex"
|
|
// passing a key re-mounts the reader when changing chapters
|
|
render={(props:any) => <Reader key={props.match.params.chapterIndex} />}
|
|
/>
|
|
</Switch>
|
|
</NavbarContext.Provider>
|
|
</ThemeProvider>
|
|
</Router>
|
|
);
|
|
}
|