1
0
mirror of https://github.com/xuthus83/pigallery2.git synced 2025-01-14 14:43:17 +08:00
pigallery2/frontend/app/gallery/search/search.gallery.component.ts

144 lines
4.1 KiB
TypeScript
Raw Normal View History

2018-05-03 19:17:08 -04:00
import {Component, OnDestroy} from '@angular/core';
2018-03-30 15:30:30 -04:00
import {AutoCompleteService} from './autocomplete.service';
import {AutoCompleteItem, SearchTypes} from '../../../../common/entities/AutoCompleteItem';
import {ActivatedRoute, Params, RouterLink} from '@angular/router';
import {GalleryService} from '../gallery.service';
2018-11-28 23:49:33 +01:00
import {Subscription} from 'rxjs';
2018-03-30 15:30:30 -04:00
import {Config} from '../../../../common/config/public/Config';
import {NavigationService} from '../../model/navigation.service';
import {QueryParams} from '../../../../common/QueryParams';
@Component({
2018-05-03 19:17:08 -04:00
selector: 'app-gallery-search',
templateUrl: './search.gallery.component.html',
styleUrls: ['./search.gallery.component.css'],
providers: [AutoCompleteService, RouterLink]
})
2018-05-03 19:17:08 -04:00
export class GallerySearchComponent implements OnDestroy {
2016-05-09 17:04:56 +02:00
2018-11-28 23:49:33 +01:00
autoCompleteItems: AutoCompleteRenderItem[] = [];
2018-05-03 19:17:08 -04:00
public searchText = '';
private cache = {
2018-03-30 15:30:30 -04:00
lastAutocomplete: '',
lastInstantSearch: ''
};
2018-05-03 19:17:08 -04:00
mouseOverAutoComplete = false;
2018-11-28 23:49:33 +01:00
readonly SearchTypes: typeof SearchTypes;
private readonly subscription: Subscription = null;
2017-07-03 19:17:49 +02:00
constructor(private _autoCompleteService: AutoCompleteService,
private _galleryService: GalleryService,
private navigationService: NavigationService,
private _route: ActivatedRoute) {
2016-05-16 11:03:11 +02:00
this.SearchTypes = SearchTypes;
2016-12-26 23:36:38 +01:00
2017-07-03 19:17:49 +02:00
this.subscription = this._route.params.subscribe((params: Params) => {
const searchText = params[QueryParams.gallery.searchText];
2018-05-03 19:17:08 -04:00
if (searchText && searchText !== '') {
2017-07-03 19:17:49 +02:00
this.searchText = searchText;
}
});
}
2017-07-03 19:17:49 +02:00
ngOnDestroy() {
if (this.subscription !== null) {
2018-03-30 15:30:30 -04:00
this.subscription.unsubscribe();
2017-07-03 19:17:49 +02:00
}
}
onSearchChange(event: KeyboardEvent) {
2016-05-09 21:43:52 +02:00
2018-05-03 19:17:08 -04:00
const searchText = (<HTMLInputElement>event.target).value.trim();
if (Config.Client.Search.autocompleteEnabled &&
this.cache.lastAutocomplete !== searchText) {
this.cache.lastAutocomplete = searchText;
this.autocomplete(searchText).catch(console.error);
}
if (Config.Client.Search.instantSearchEnabled &&
this.cache.lastInstantSearch !== searchText) {
this.cache.lastInstantSearch = searchText;
if (searchText === '') {
return this.navigationService.toGallery().catch(console.error);
}
this._galleryService.runInstantSearch(searchText);
this.navigationService.search(searchText).catch(console.error);
2016-05-09 21:43:52 +02:00
}
}
2016-05-09 17:04:56 +02:00
public setMouseOverAutoComplete(value: boolean) {
this.mouseOverAutoComplete = value;
}
public onFocusLost() {
2018-05-03 19:17:08 -04:00
if (this.mouseOverAutoComplete === false) {
this.autoCompleteItems = [];
}
}
public onFocus() {
this.autocomplete(this.searchText).catch(console.error);
}
private emptyAutoComplete() {
this.autoCompleteItems = [];
}
2017-07-03 19:17:49 +02:00
private async autocomplete(searchText: string) {
if (!Config.Client.Search.autocompleteEnabled) {
2018-03-30 15:30:30 -04:00
return;
}
2018-05-03 19:17:08 -04:00
if (searchText.trim() === '.') {
2017-07-08 00:18:24 +02:00
return;
}
2017-07-03 19:17:49 +02:00
if (searchText.trim().length > 0) {
2017-07-03 19:17:49 +02:00
try {
const items = await this._autoCompleteService.autoComplete(searchText);
this.showSuggestions(items, searchText);
} catch (error) {
console.error(error);
}
} else {
this.emptyAutoComplete();
}
}
private showSuggestions(suggestions: AutoCompleteItem[], searchText: string) {
this.emptyAutoComplete();
suggestions.forEach((item: AutoCompleteItem) => {
2018-05-03 19:17:08 -04:00
const renderItem = new AutoCompleteRenderItem(item.text, searchText, item.type);
this.autoCompleteItems.push(renderItem);
});
}
}
2016-05-09 17:04:56 +02:00
class AutoCompleteRenderItem {
2018-05-03 19:17:08 -04:00
public preText = '';
public highLightText = '';
public postText = '';
public type: SearchTypes;
constructor(public text: string, searchText: string, type: SearchTypes) {
2018-05-03 19:17:08 -04:00
const preIndex = text.toLowerCase().indexOf(searchText.toLowerCase());
if (preIndex > -1) {
this.preText = text.substring(0, preIndex);
this.highLightText = text.substring(preIndex, preIndex + searchText.length);
this.postText = text.substring(preIndex + searchText.length);
} else {
this.postText = text;
}
this.type = type;
}
}