From c537c1bf29b600db9cb73fa20815e1de3147bf48 Mon Sep 17 00:00:00 2001 From: Aria Moradi Date: Wed, 20 Jan 2021 15:26:52 +0330 Subject: [PATCH] manga search UI done --- .../main/kotlin/ir/armor/tachidesk/Main.kt | 15 +++--- webUI/react/src/App.tsx | 4 ++ webUI/react/src/components/MangaGrid.tsx | 26 ++++++++++ .../react/src/components/TemporaryDrawer.tsx | 8 ++++ webUI/react/src/screens/MangaList.tsx | 17 +------ webUI/react/src/screens/Search.tsx | 48 +++++++++++++++++++ 6 files changed, 97 insertions(+), 21 deletions(-) create mode 100644 webUI/react/src/components/MangaGrid.tsx create mode 100644 webUI/react/src/screens/Search.tsx diff --git a/server/src/main/kotlin/ir/armor/tachidesk/Main.kt b/server/src/main/kotlin/ir/armor/tachidesk/Main.kt index 0324799..965f2f4 100644 --- a/server/src/main/kotlin/ir/armor/tachidesk/Main.kt +++ b/server/src/main/kotlin/ir/armor/tachidesk/Main.kt @@ -36,10 +36,13 @@ class Main { androidCompat.startApp(App()) - val app = Javalin.create { config -> - // config.addSinglePageRoot("/", "") - config.addStaticFiles("/react") + try { + this::class.java.classLoader.getResource("/react/index.html") + config.addStaticFiles("/react") + } catch (e: RuntimeException) { + println("Warning: react build files are missing.") + } }.start(4567) @@ -68,12 +71,12 @@ class Main { app.get("/api/v1/source/:sourceId/popular/:pageNum") { ctx -> val sourceId = ctx.pathParam("sourceId").toLong() val pageNum = ctx.pathParam("pageNum").toInt() - ctx.json(getMangaList(sourceId,pageNum,popular = true)) + ctx.json(getMangaList(sourceId, pageNum, popular = true)) } app.get("/api/v1/source/:sourceId/latest/:pageNum") { ctx -> val sourceId = ctx.pathParam("sourceId").toLong() val pageNum = ctx.pathParam("pageNum").toInt() - ctx.json(getMangaList(sourceId,pageNum,popular = false)) + ctx.json(getMangaList(sourceId, pageNum, popular = false)) } app.get("/api/v1/manga/:mangaId/") { ctx -> @@ -89,7 +92,7 @@ class Main { app.get("/api/v1/manga/:mangaId/chapter/:chapterId") { ctx -> val chapterId = ctx.pathParam("chapterId").toInt() val mangaId = ctx.pathParam("mangaId").toInt() - ctx.json(getPages(chapterId,mangaId)) + ctx.json(getPages(chapterId, mangaId)) } } diff --git a/webUI/react/src/App.tsx b/webUI/react/src/App.tsx index 040f420..21d6b3b 100644 --- a/webUI/react/src/App.tsx +++ b/webUI/react/src/App.tsx @@ -9,6 +9,7 @@ import Extensions from './screens/Extensions'; import MangaList from './screens/MangaList'; import Manga from './screens/Manga'; import Reader from './screens/Reader'; +import Search from './screens/Search'; export default function App() { return ( @@ -16,6 +17,9 @@ export default function App() { + + + diff --git a/webUI/react/src/components/MangaGrid.tsx b/webUI/react/src/components/MangaGrid.tsx new file mode 100644 index 0000000..891397a --- /dev/null +++ b/webUI/react/src/components/MangaGrid.tsx @@ -0,0 +1,26 @@ +import React from 'react'; +import MangaCard from './MangaCard'; + +interface IProps{ + mangas: IManga[] + message?: string +} + +export default function MangaGrid(props: IProps) { + const { mangas, message } = props; + let mapped; + + if (mangas.length === 0) { + mapped =

{message !== undefined ? message : 'loading...'}

; + } else { + mapped = ( +
+ {mangas.map((it) => ( + + ))} +
+ ); + } + + return mapped; +} diff --git a/webUI/react/src/components/TemporaryDrawer.tsx b/webUI/react/src/components/TemporaryDrawer.tsx index 9a1e4d0..6895d4b 100644 --- a/webUI/react/src/components/TemporaryDrawer.tsx +++ b/webUI/react/src/components/TemporaryDrawer.tsx @@ -48,6 +48,14 @@ export default function TemporaryDrawer({ drawerOpen, setDrawerOpen }: IProps) { + + + + + + + + ); diff --git a/webUI/react/src/screens/MangaList.tsx b/webUI/react/src/screens/MangaList.tsx index d7d86f4..93ba238 100644 --- a/webUI/react/src/screens/MangaList.tsx +++ b/webUI/react/src/screens/MangaList.tsx @@ -1,10 +1,9 @@ import React, { useEffect, useState } from 'react'; import { useParams } from 'react-router-dom'; -import MangaCard from '../components/MangaCard'; +import MangaGrid from '../components/MangaGrid'; export default function MangaList(props: { popular: boolean }) { const { sourceId } = useParams<{sourceId: string}>(); - let mapped; const [mangas, setMangas] = useState([]); const [lastPageNum] = useState(1); @@ -17,17 +16,5 @@ export default function MangaList(props: { popular: boolean }) { )); }, []); - if (mangas.length === 0) { - mapped =

wait

; - } else { - mapped = ( -
- {mangas.map((it) => ( - - ))} -
- ); - } - - return mapped; + return ; } diff --git a/webUI/react/src/screens/Search.tsx b/webUI/react/src/screens/Search.tsx new file mode 100644 index 0000000..b79f977 --- /dev/null +++ b/webUI/react/src/screens/Search.tsx @@ -0,0 +1,48 @@ +import React, { useState } from 'react'; +import { makeStyles } from '@material-ui/core/styles'; +import TextField from '@material-ui/core/TextField'; +import Button from '@material-ui/core/Button'; +import MangaGrid from '../components/MangaGrid'; + +const useStyles = makeStyles((theme) => ({ + root: { + TextField: { + margin: theme.spacing(1), + width: '25ch', + }, + }, +})); + +export default function Search() { + const classes = useStyles(); + const [error, setError] = useState(false); + const [mangas, setMangas] = useState([]); + const [message, setMessage] = useState(''); + + const textInput = React.createRef(); + + function doSearch() { + if (textInput.current) { + const { value } = textInput.current; + if (value === '') { setError(true); } else { + setError(false); + setMangas([]); + setMessage('button pressed'); + } + } + } + + const mangaGrid = ; + + return ( + <> +
+ + + + {mangaGrid} + + ); +}