1
0
mirror of https://github.com/xuthus83/pigallery2.git synced 2024-11-03 21:04:03 +08:00
pigallery2/frontend/app/gallery/cache.gallery.service.ts

168 lines
5.2 KiB
TypeScript
Raw Normal View History

2018-03-31 03:30:30 +08:00
import {Injectable} from '@angular/core';
import {PhotoDTO} from '../../../common/entities/PhotoDTO';
import {DirectoryDTO} from '../../../common/entities/DirectoryDTO';
import {Utils} from '../../../common/Utils';
import {Config} from '../../../common/config/public/Config';
import {AutoCompleteItem, SearchTypes} from '../../../common/entities/AutoCompleteItem';
import {SearchResultDTO} from '../../../common/entities/SearchResultDTO';
2018-11-05 02:28:32 +08:00
import {MediaDTO} from '../../../common/entities/MediaDTO';
2017-07-30 05:39:06 +08:00
2017-07-30 15:06:12 +08:00
interface CacheItem<T> {
2017-07-30 05:39:06 +08:00
timestamp: number;
2017-07-30 15:06:12 +08:00
item: T;
2017-07-30 05:39:06 +08:00
}
2016-06-26 17:08:05 +08:00
@Injectable()
export class GalleryCacheService {
2018-03-31 03:30:30 +08:00
private static CONTENT_PREFIX = 'content:';
private static AUTO_COMPLETE_PREFIX = 'autocomplete:';
private static INSTANT_SEARCH_PREFIX = 'instant_search:';
private static SEARCH_PREFIX = 'search:';
private static SEARCH_TYPE_PREFIX = ':type:';
2017-07-30 05:39:06 +08:00
public getAutoComplete(text: string): Array<AutoCompleteItem> {
const key = GalleryCacheService.AUTO_COMPLETE_PREFIX + text;
const tmp = localStorage.getItem(key);
if (tmp != null) {
2017-07-30 15:06:12 +08:00
const value: CacheItem<Array<AutoCompleteItem>> = JSON.parse(tmp);
2017-07-30 05:39:06 +08:00
if (value.timestamp < Date.now() - Config.Client.Search.autocompleteCacheTimeout) {
localStorage.removeItem(key);
return null;
}
2017-07-30 15:06:12 +08:00
return value.item;
2017-07-30 05:39:06 +08:00
}
return null;
}
2017-07-30 15:06:12 +08:00
public setAutoComplete(text: string, items: Array<AutoCompleteItem>): void {
const tmp: CacheItem<Array<AutoCompleteItem>> = {
2017-07-30 05:39:06 +08:00
timestamp: Date.now(),
2017-07-30 15:06:12 +08:00
item: items
2017-07-30 05:39:06 +08:00
};
localStorage.setItem(GalleryCacheService.AUTO_COMPLETE_PREFIX + text, JSON.stringify(tmp));
}
2016-06-26 17:08:05 +08:00
2017-07-30 15:06:12 +08:00
public getInstantSearch(text: string): SearchResultDTO {
const key = GalleryCacheService.INSTANT_SEARCH_PREFIX + text;
const tmp = localStorage.getItem(key);
if (tmp != null) {
const value: CacheItem<SearchResultDTO> = JSON.parse(tmp);
if (value.timestamp < Date.now() - Config.Client.Search.instantSearchCacheTimeout) {
localStorage.removeItem(key);
return null;
}
return value.item;
}
return null;
}
public setInstantSearch(text: string, searchResult: SearchResultDTO): void {
const tmp: CacheItem<SearchResultDTO> = {
timestamp: Date.now(),
item: searchResult
};
localStorage.setItem(GalleryCacheService.INSTANT_SEARCH_PREFIX + text, JSON.stringify(tmp));
}
public getSearch(text: string, type?: SearchTypes): SearchResultDTO {
let key = GalleryCacheService.SEARCH_PREFIX + text;
if (typeof type !== 'undefined') {
2017-07-30 15:06:12 +08:00
key += GalleryCacheService.SEARCH_TYPE_PREFIX + type;
}
const tmp = localStorage.getItem(key);
if (tmp != null) {
const value: CacheItem<SearchResultDTO> = JSON.parse(tmp);
if (value.timestamp < Date.now() - Config.Client.Search.searchCacheTimeout) {
localStorage.removeItem(key);
return null;
}
return value.item;
}
return null;
}
public setSearch(text: string, type: SearchTypes, searchResult: SearchResultDTO): void {
const tmp: CacheItem<SearchResultDTO> = {
timestamp: Date.now(),
item: searchResult
};
let key = GalleryCacheService.SEARCH_PREFIX + text;
if (typeof type !== 'undefined') {
2017-07-30 15:06:12 +08:00
key += GalleryCacheService.SEARCH_TYPE_PREFIX + type;
}
localStorage.setItem(key, JSON.stringify(tmp));
}
public getDirectory(directoryName: string): DirectoryDTO {
if (Config.Client.Other.enableCache === false) {
return null;
}
2018-11-19 05:23:25 +08:00
try {
const value = localStorage.getItem(GalleryCacheService.CONTENT_PREFIX + Utils.concatUrls(directoryName));
if (value != null) {
const directory: DirectoryDTO = JSON.parse(value);
2016-06-26 17:08:05 +08:00
2018-11-19 05:23:25 +08:00
DirectoryDTO.addReferences(directory);
return directory;
}
} catch (e) {
2016-06-26 17:08:05 +08:00
}
return null;
}
2016-06-26 17:08:05 +08:00
public setDirectory(directory: DirectoryDTO): void {
if (Config.Client.Other.enableCache === false) {
return;
}
2016-12-27 06:36:38 +08:00
2017-07-30 05:39:06 +08:00
const key = GalleryCacheService.CONTENT_PREFIX + Utils.concatUrls(directory.path, directory.name);
if (directory.isPartial === true && localStorage.getItem(key)) {
2017-07-22 01:14:22 +08:00
return;
}
localStorage.setItem(key, JSON.stringify(directory));
2016-06-26 17:08:05 +08:00
directory.directories.forEach((dir: DirectoryDTO) => {
const sub_key = GalleryCacheService.CONTENT_PREFIX + Utils.concatUrls(dir.path, dir.name);
if (localStorage.getItem(sub_key) == null) { // don't override existing
localStorage.setItem(sub_key, JSON.stringify(dir));
}
});
2016-06-26 17:08:05 +08:00
}
2016-06-26 17:08:05 +08:00
/**
2018-11-05 02:28:32 +08:00
* Update media state at cache too (Eg.: thumbnail rendered)
* @param media
*/
2018-11-05 02:28:32 +08:00
public mediaUpdated(media: MediaDTO): void {
if (Config.Client.Other.enableCache === false) {
return;
}
2018-11-05 02:28:32 +08:00
const directoryName = Utils.concatUrls(media.directory.path, media.directory.name);
const value = localStorage.getItem(directoryName);
if (value != null) {
const directory: DirectoryDTO = JSON.parse(value);
2018-11-05 02:28:32 +08:00
directory.media.forEach((p) => {
if (p.name === media.name) {
// update data
2018-11-05 02:28:32 +08:00
p.metadata = media.metadata;
p.readyThumbnails = media.readyThumbnails;
// save changes
localStorage.setItem(directoryName, JSON.stringify(directory));
return;
}
});
}
2016-06-26 17:08:05 +08:00
}
2016-06-26 17:08:05 +08:00
}