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';
|
|
|
|
import {Config} from '../../../../common/config/public/Config';
|
2016-05-03 21:04:57 +02:00
|
|
|
|
|
|
|
@Component({
|
2018-05-03 19:17:08 -04:00
|
|
|
selector: 'app-gallery-search',
|
2017-06-10 22:32:56 +02:00
|
|
|
templateUrl: './search.gallery.component.html',
|
|
|
|
styleUrls: ['./search.gallery.component.css'],
|
|
|
|
providers: [AutoCompleteService, RouterLink]
|
2016-05-03 21:04:57 +02:00
|
|
|
})
|
2018-05-03 19:17:08 -04:00
|
|
|
export class GallerySearchComponent implements OnDestroy {
|
2016-05-09 17:04:56 +02:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
autoCompleteItems: Array<AutoCompleteRenderItem> = [];
|
2018-05-03 19:17:08 -04:00
|
|
|
public searchText = '';
|
2017-06-10 22:32:56 +02:00
|
|
|
private cache = {
|
2018-03-30 15:30:30 -04:00
|
|
|
lastAutocomplete: '',
|
|
|
|
lastInstantSearch: ''
|
2017-06-10 22:32:56 +02:00
|
|
|
};
|
2016-05-09 17:04:56 +02:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
SearchTypes: any = [];
|
2018-05-03 19:17:08 -04:00
|
|
|
mouseOverAutoComplete = false;
|
|
|
|
private readonly subscription = null;
|
2017-07-03 19:17:49 +02:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
constructor(private _autoCompleteService: AutoCompleteService,
|
|
|
|
private _galleryService: GalleryService,
|
|
|
|
private _route: ActivatedRoute) {
|
2016-05-16 11:03:11 +02:00
|
|
|
|
2017-06-10 22:32:56 +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) => {
|
2018-05-03 19:17:08 -04:00
|
|
|
const searchText = params['searchText'];
|
|
|
|
if (searchText && searchText !== '') {
|
2017-07-03 19:17:49 +02:00
|
|
|
this.searchText = searchText;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2016-05-03 21:04:57 +02:00
|
|
|
|
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
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
2016-05-10 10:59:12 +02:00
|
|
|
|
2017-06-10 22:32:56 +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();
|
2016-05-10 21:33:58 +02:00
|
|
|
|
2018-05-03 19:17:08 -04:00
|
|
|
if (Config.Client.Search.autocompleteEnabled && this.cache.lastAutocomplete !== searchText) {
|
2017-06-10 22:32:56 +02:00
|
|
|
this.cache.lastAutocomplete = searchText;
|
|
|
|
this.autocomplete(searchText);
|
2016-05-03 21:04:57 +02:00
|
|
|
}
|
|
|
|
|
2018-05-03 19:17:08 -04:00
|
|
|
if (Config.Client.Search.instantSearchEnabled && this.cache.lastInstantSearch !== searchText) {
|
2017-06-10 22:32:56 +02:00
|
|
|
this.cache.lastInstantSearch = searchText;
|
|
|
|
this._galleryService.instantSearch(searchText);
|
2016-05-09 21:43:52 +02:00
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
2016-05-10 10:59:12 +02:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
public onSearch() {
|
2017-07-13 23:39:09 +02:00
|
|
|
if (Config.Client.Search.enabled) {
|
2017-06-10 22:32:56 +02:00
|
|
|
this._galleryService.search(this.searchText);
|
2016-05-10 10:59:12 +02:00
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
2016-05-10 10:59:12 +02:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
public search(item: AutoCompleteItem) {
|
|
|
|
this.searchText = item.text;
|
|
|
|
this.onSearch();
|
|
|
|
}
|
2016-05-10 21:33:58 +02:00
|
|
|
|
2016-05-09 17:04:56 +02:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
public setMouseOverAutoComplete(value: boolean) {
|
|
|
|
this.mouseOverAutoComplete = value;
|
|
|
|
}
|
2016-05-03 21:04:57 +02:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
public onFocusLost() {
|
2018-05-03 19:17:08 -04:00
|
|
|
if (this.mouseOverAutoComplete === false) {
|
2017-06-10 22:32:56 +02:00
|
|
|
this.autoCompleteItems = [];
|
2016-05-10 10:59:12 +02:00
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
2016-05-10 10:59:12 +02:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
public onFocus() {
|
|
|
|
this.autocomplete(this.searchText);
|
|
|
|
}
|
2016-05-03 21:04:57 +02:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
private emptyAutoComplete() {
|
|
|
|
this.autoCompleteItems = [];
|
|
|
|
}
|
|
|
|
|
2017-07-03 19:17:49 +02:00
|
|
|
private async autocomplete(searchText: string) {
|
2017-06-10 22:32:56 +02:00
|
|
|
if (!Config.Client.Search.autocompleteEnabled) {
|
2018-03-30 15:30:30 -04:00
|
|
|
return;
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
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
|
|
|
|
2017-06-10 22:32:56 +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);
|
|
|
|
}
|
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
} else {
|
|
|
|
this.emptyAutoComplete();
|
2016-05-10 10:59:12 +02:00
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
}
|
2016-05-03 21:04:57 +02:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
private showSuggestions(suggestions: Array<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);
|
2017-06-10 22:32:56 +02:00
|
|
|
this.autoCompleteItems.push(renderItem);
|
|
|
|
});
|
|
|
|
}
|
2016-05-10 21:33:58 +02:00
|
|
|
|
2017-06-10 22:32:56 +02:00
|
|
|
public setSearchText(searchText: string) {
|
|
|
|
this.searchText = searchText;
|
|
|
|
}
|
2016-05-16 11:03:11 +02:00
|
|
|
|
2016-05-03 21:04:57 +02:00
|
|
|
}
|
|
|
|
|
2016-05-09 17:04:56 +02:00
|
|
|
class AutoCompleteRenderItem {
|
2018-05-03 19:17:08 -04:00
|
|
|
public preText = '';
|
|
|
|
public highLightText = '';
|
|
|
|
public postText = '';
|
2017-06-10 22:32:56 +02:00
|
|
|
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());
|
2017-06-10 22:32:56 +02:00
|
|
|
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;
|
2016-05-03 21:04:57 +02:00
|
|
|
}
|
2017-06-10 22:32:56 +02:00
|
|
|
this.type = type;
|
|
|
|
}
|
2016-05-03 21:04:57 +02:00
|
|
|
}
|
|
|
|
|