feat: use map instead of interface

This commit is contained in:
2024-07-14 23:50:16 +03:00
parent 5a4206a81e
commit 45389364ff
4 changed files with 21 additions and 24 deletions

View File

@@ -9,5 +9,8 @@
// "**/node_modules": true, // "**/node_modules": true,
"**/.angular": true "**/.angular": true
}, },
"editor.formatOnSave": true "editor.formatOnSave": true,
"cSpell.words": [
"Manhwa"
]
} }

View File

@@ -11,7 +11,7 @@
<h3>{{ currentChapterInfo?.number }}. {{ currentChapterInfo?.name || "Нет названия" }}</h3> <h3>{{ currentChapterInfo?.number }}. {{ currentChapterInfo?.name || "Нет названия" }}</h3>
</div> </div>
<div class="flex flex-col items-center"> <div class="flex flex-col items-center">
@if (pages.length > 0 && cachedPages[currentPageIndex]) { @if (pages.length > 0 && cachedPages.get(currentPageIndex)) {
<div [class]="imageContainerClass"> <div [class]="imageContainerClass">
@if (!isManhwa$.value) { @if (!isManhwa$.value) {
<app-scale-image [imageSrc]="imageUrl"></app-scale-image> <app-scale-image [imageSrc]="imageUrl"></app-scale-image>

View File

@@ -28,7 +28,7 @@ export class ReaderComponent implements AfterViewInit, OnDestroy {
//FIXME: Scrolling to top when manhwa //FIXME: Scrolling to top when manhwa
pages: Page[] = []; pages: Page[] = [];
currentPageIndex = 0; currentPageIndex = 0;
cachedPages: CachedPages = {}; cachedPages: CachedPages = new Map<number, CachedPage>();
imageUrl: string = ""; imageUrl: string = "";
isManhwa = false; isManhwa = false;
currentChapterInfo: Chapter | null = null; currentChapterInfo: Chapter | null = null;
@@ -53,7 +53,7 @@ export class ReaderComponent implements AfterViewInit, OnDestroy {
} }
get manhwaPages() { get manhwaPages() {
return Object.values(this.cachedPages) as CachedPage[]; return this.cachedPages.values();
} }
ngAfterViewInit(): void { ngAfterViewInit(): void {
@@ -154,7 +154,6 @@ export class ReaderComponent implements AfterViewInit, OnDestroy {
this.cachePage(index); // Кэшируем текущую и соседние страницы this.cachePage(index); // Кэшируем текущую и соседние страницы
if (!this.isManhwa$.value) this.unloadCachedPages(index); // Сгружаем ненужные страницы из кэша if (!this.isManhwa$.value) this.unloadCachedPages(index); // Сгружаем ненужные страницы из кэша
if (!this.isManhwa$.value) { if (!this.isManhwa$.value) {
console.log("scroll");
const container = document.querySelector("app-reader"); const container = document.querySelector("app-reader");
if (container) { if (container) {
container.scrollTo({ container.scrollTo({
@@ -163,7 +162,7 @@ export class ReaderComponent implements AfterViewInit, OnDestroy {
}); });
} }
} }
if (!this.cachedPages[index]?.imageData) { if (!this.cachedPages.get(index)?.imageData) {
// Если страница не закэширована, загружаем её // Если страница не закэширована, загружаем её
this.fetchAndCachePage(index) this.fetchAndCachePage(index)
.pipe(takeUntil(this.destroy$)) .pipe(takeUntil(this.destroy$))
@@ -181,7 +180,7 @@ export class ReaderComponent implements AfterViewInit, OnDestroy {
const nextChapterIndex = Math.min(thisChapterIndex + 1, this.chaptersInfo.length - 1); const nextChapterIndex = Math.min(thisChapterIndex + 1, this.chaptersInfo.length - 1);
const nextChapter = this.chaptersInfo[nextChapterIndex]; const nextChapter = this.chaptersInfo[nextChapterIndex];
if (nextChapter !== this.chaptersInfo[thisChapterIndex]) { if (nextChapter !== this.chaptersInfo[thisChapterIndex]) {
this.cachedPages = []; this.cachedPages.clear();
this.router.navigate(["/", "reader"], { this.router.navigate(["/", "reader"], {
queryParams: { queryParams: {
url: this.url, url: this.url,
@@ -197,7 +196,7 @@ export class ReaderComponent implements AfterViewInit, OnDestroy {
const prevChapterIndex = Math.max(thisChapterIndex - 1, 0); const prevChapterIndex = Math.max(thisChapterIndex - 1, 0);
const prevChapter = this.chaptersInfo[prevChapterIndex]; const prevChapter = this.chaptersInfo[prevChapterIndex];
if (prevChapter !== this.chaptersInfo[thisChapterIndex]) { if (prevChapter !== this.chaptersInfo[thisChapterIndex]) {
this.cachedPages = []; this.cachedPages.clear();
this.router.navigate(["/", "reader"], { this.router.navigate(["/", "reader"], {
queryParams: { queryParams: {
url: this.url, url: this.url,
@@ -229,7 +228,7 @@ export class ReaderComponent implements AfterViewInit, OnDestroy {
} }
private isPageCached(index: number): boolean { private isPageCached(index: number): boolean {
return !!this.cachedPages[index]?.imageData; return !!this.cachedPages.get(index)?.imageData;
} }
// Загрузка и сохранение изображения в кэш // Загрузка и сохранение изображения в кэш
@@ -239,15 +238,12 @@ export class ReaderComponent implements AfterViewInit, OnDestroy {
.pipe( .pipe(
map((imageData) => { map((imageData) => {
const url = this.getImageUrl(imageData); const url = this.getImageUrl(imageData);
this.cachedPages = { this.cachedPages.set(index, {
...this.cachedPages,
[index]: {
...this.pages[index], ...this.pages[index],
imageData, imageData,
imageUrl: url, imageUrl: url,
isManhwa: +this.pages[index].ratio < 0.5, isManhwa: +this.pages[index].ratio < 0.5,
}, });
};
}), }),
); );
} }
@@ -257,7 +253,7 @@ export class ReaderComponent implements AfterViewInit, OnDestroy {
for (const key in this.cachedPages) { for (const key in this.cachedPages) {
const pageIndex = +key; const pageIndex = +key;
if (index - pageIndex > 2) { if (index - pageIndex > 2) {
delete this.cachedPages[pageIndex]; this.cachedPages.delete(pageIndex);
} }
} }
} }
@@ -273,7 +269,7 @@ export class ReaderComponent implements AfterViewInit, OnDestroy {
// Обновляем изображение на странице // Обновляем изображение на странице
private updateImage() { private updateImage() {
const currentPage = this.cachedPages[this.currentPageIndex]; const currentPage = this.cachedPages.get(this.currentPageIndex);
if (currentPage && currentPage.imageData && !this.isManhwa$.value) { if (currentPage && currentPage.imageData && !this.isManhwa$.value) {
const blob = new Blob([currentPage.imageData], { type: "image/jpeg" }); const blob = new Blob([currentPage.imageData], { type: "image/jpeg" });
const urlCreator = window.URL || window.webkitURL; const urlCreator = window.URL || window.webkitURL;

View File

@@ -7,6 +7,4 @@ export interface CachedPage extends Page {
isManhwa: boolean; isManhwa: boolean;
} }
export interface CachedPages { export type CachedPages = Map<number, CachedPage>;
[key: number]: CachedPage;
}