From 335033dde89d609701d7ee00e7d42ed98ab069f5 Mon Sep 17 00:00:00 2001 From: "Patrik J. Braun" Date: Sun, 5 Mar 2023 23:45:00 +0100 Subject: [PATCH] Fixing search caching bug --- src/frontend/app/ui/gallery/cache.gallery.service.ts | 3 +++ src/frontend/app/ui/gallery/content.service.ts | 6 +++--- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/src/frontend/app/ui/gallery/cache.gallery.service.ts b/src/frontend/app/ui/gallery/cache.gallery.service.ts index 2b335d73..20818b31 100644 --- a/src/frontend/app/ui/gallery/cache.gallery.service.ts +++ b/src/frontend/app/ui/gallery/cache.gallery.service.ts @@ -183,6 +183,9 @@ export class GalleryCacheService { if (Config.Gallery.enableCache === false) { return null; } + if (typeof query === 'string') { + throw new Error('query expected to by object. Got:' + query); + } const key = GalleryCacheService.SEARCH_PREFIX + JSON.stringify(query); return GalleryCacheService.loadCacheItem(key); } diff --git a/src/frontend/app/ui/gallery/content.service.ts b/src/frontend/app/ui/gallery/content.service.ts index 9adb9378..bd9ca59a 100644 --- a/src/frontend/app/ui/gallery/content.service.ts +++ b/src/frontend/app/ui/gallery/content.service.ts @@ -26,7 +26,7 @@ export class ContentService { }; private lastDirectory: ParentDirectoryDTO; private searchId: any; - private ongoingSearch: SearchQueryDTO = null; + private ongoingSearch: string = null; constructor( private networkService: NetworkService, @@ -102,7 +102,7 @@ export class ContentService { } } - public async search(query: SearchQueryDTO): Promise { + public async search(query: string): Promise { if (this.searchId != null) { clearTimeout(this.searchId); } @@ -110,7 +110,7 @@ export class ContentService { this.ongoingSearch = query; this.setContent(new ContentWrapperWithError()); - let cw = this.galleryCacheService.getSearch(query); + let cw = this.galleryCacheService.getSearch(JSON.parse(query)); if (!cw || cw.searchResult == null) { try { cw = await this.networkService.getJson('/search/' + query);