mirror of
https://github.com/C9Glax/tranga-website.git
synced 2025-04-19 14:53:20 +02:00
51 lines
2.5 KiB
TypeScript
51 lines
2.5 KiB
TypeScript
import React, {ReactElement, ReactEventHandler, useEffect, useState} from "react";
|
|
import MangaFunctions from "../MangaFunctions";
|
|
import IManga from "./IManga";
|
|
import ChapterFunctions from "../ChapterFunctions";
|
|
|
|
export default interface IChapter{
|
|
chapterId: string;
|
|
volumeNumber: number;
|
|
chapterNumber: string;
|
|
url: string;
|
|
title: string | undefined;
|
|
archiveFileName: string;
|
|
downloaded: boolean;
|
|
parentMangaId: string;
|
|
}
|
|
|
|
export function ChapterItem({apiUri, chapterId} : {apiUri: string, chapterId: string}) : ReactElement {
|
|
const setCoverItem : ReactEventHandler<HTMLImageElement> = (e) => {
|
|
setMangaCoverHtmlImageItem(e.currentTarget);
|
|
}
|
|
|
|
let [chapter, setChapter] = useState<IChapter | null>(null);
|
|
let [manga, setManga] = useState<IManga | null>(null);
|
|
let [mangaCoverUrl, setMangaCoverUrl] = useState<string>("../../media/blahaj.png");
|
|
let [mangaCoverHtmlImageItem, setMangaCoverHtmlImageItem] = useState<HTMLImageElement | null>(null);
|
|
useEffect(() => {
|
|
ChapterFunctions.GetChapterFromId(apiUri, chapterId).then(setChapter);
|
|
}, []);
|
|
useEffect(() => {
|
|
if(chapter === null)
|
|
manga = null;
|
|
else
|
|
MangaFunctions.GetMangaById(apiUri, chapter.parentMangaId).then(setManga);
|
|
}, [chapter]);
|
|
useEffect(() => {
|
|
if(chapter != null && mangaCoverHtmlImageItem != null)
|
|
setMangaCoverUrl(MangaFunctions.GetMangaCoverImageUrl(apiUri, chapter.parentMangaId, mangaCoverHtmlImageItem));
|
|
}, [chapter, mangaCoverHtmlImageItem]);
|
|
|
|
let [clicked, setClicked] = useState<boolean>(false);
|
|
|
|
return (<div className="ChapterItem" key={chapterId} is-clicked={clicked ? "clicked" : "not-clicked"} onClick={() => setClicked(!clicked)}>
|
|
<img className="ChapterItem-Cover" src={mangaCoverUrl} alt="MangaFunctions Cover" onLoad={setCoverItem} onResize={setCoverItem}></img>
|
|
<p className="ChapterItem-MangaName">{manga ? manga.name : "MangaFunctions-Name"}</p>
|
|
<p className="ChapterItem-ChapterName">{chapter ? chapter.title : "ChapterFunctions-Title"}</p>
|
|
<p className="ChapterItem-Volume">Vol.{chapter ? chapter.volumeNumber : "VolNum"}</p>
|
|
<p className="ChapterItem-Chapter">Ch.{chapter ? chapter.chapterNumber : "ChNum"}</p>
|
|
<p className="ChapterItem-VolumeChapter">Vol.{chapter ? chapter.volumeNumber : "VolNum"} Ch.{chapter ? chapter.chapterNumber : "ChNum"}</p>
|
|
<a className="ChapterItem-Website" href={chapter ? chapter.url : "#"}><img src="../../media/link.svg" alt="Link"/></a>
|
|
</div>)
|
|
} |