2016-05-03 21:04:57 +02:00
|
|
|
///<reference path="../../../browser.d.ts"/>
|
|
|
|
|
2016-05-04 17:20:21 +02:00
|
|
|
import {Component} from "@angular/core";
|
2016-05-03 21:04:57 +02:00
|
|
|
import {AutoCompleteService} from "./autocomplete.service";
|
2016-05-04 18:34:54 +02:00
|
|
|
import {AutoCompleteItem} from "../../../../common/entities/AutoCompleteItem";
|
|
|
|
import {Message} from "../../../../common/entities/Message";
|
2016-05-03 21:04:57 +02:00
|
|
|
|
|
|
|
@Component({
|
|
|
|
selector: 'gallery-search',
|
|
|
|
templateUrl: 'app/gallery/search/search.gallery.component.html',
|
|
|
|
styleUrls: ['app/gallery/search/search.gallery.component.css'],
|
|
|
|
providers: [AutoCompleteService]
|
|
|
|
})
|
|
|
|
export class GallerySearchComponent {
|
|
|
|
|
2016-05-04 18:34:54 +02:00
|
|
|
autoCompleteItems:Array<AutoCompleteRenderItem> = [];
|
2016-05-03 21:04:57 +02:00
|
|
|
constructor(private _autoCompleteService:AutoCompleteService) {
|
|
|
|
}
|
|
|
|
|
|
|
|
getSuggestions(event:KeyboardEvent){
|
2016-05-04 18:34:54 +02:00
|
|
|
let searchText = (<HTMLInputElement>event.target).value;
|
2016-05-04 18:57:31 +02:00
|
|
|
if(searchText.trim().length > 0) {
|
2016-05-04 18:34:54 +02:00
|
|
|
this._autoCompleteService.autoComplete(searchText).then((message:Message<Array<AutoCompleteItem>>) =>{
|
|
|
|
if(message.error){
|
|
|
|
//TODO: implement
|
|
|
|
console.error(message.error);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
this.showSuggestions(message.result,searchText);
|
|
|
|
});
|
2016-05-04 18:57:31 +02:00
|
|
|
}else{
|
|
|
|
this.emptyAutoComplete();
|
2016-05-03 21:04:57 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-05-04 18:34:54 +02:00
|
|
|
private showSuggestions(suggestions:Array<AutoCompleteItem>,searchText:string){
|
2016-05-04 18:57:31 +02:00
|
|
|
this.emptyAutoComplete();
|
2016-05-04 18:34:54 +02:00
|
|
|
suggestions.forEach((item)=>{
|
|
|
|
let preIndex = item.text.toLowerCase().indexOf(searchText.toLowerCase());
|
|
|
|
let renderItem = new AutoCompleteRenderItem();
|
2016-05-03 21:04:57 +02:00
|
|
|
if(preIndex > -1){
|
2016-05-04 18:34:54 +02:00
|
|
|
renderItem.preText = item.text.substring(0,preIndex);
|
|
|
|
renderItem.highLightText = item.text.substring(preIndex, preIndex + searchText.length);
|
|
|
|
renderItem.postText = item.text.substring(preIndex + searchText.length);
|
2016-05-03 21:04:57 +02:00
|
|
|
}else{
|
2016-05-04 18:34:54 +02:00
|
|
|
renderItem.postText = item.text;
|
2016-05-03 21:04:57 +02:00
|
|
|
}
|
2016-05-04 18:34:54 +02:00
|
|
|
this.autoCompleteItems.push(renderItem);
|
2016-05-03 21:04:57 +02:00
|
|
|
});
|
|
|
|
}
|
2016-05-04 18:57:31 +02:00
|
|
|
|
|
|
|
public onFocusLost(event){
|
|
|
|
this.autoCompleteItems = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
private emptyAutoComplete(){
|
|
|
|
this.autoCompleteItems = [];
|
|
|
|
}
|
2016-05-03 21:04:57 +02:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2016-05-04 18:34:54 +02:00
|
|
|
class AutoCompleteRenderItem{
|
2016-05-03 21:04:57 +02:00
|
|
|
constructor(public preText:string = "",public highLightText:string = "", public postText:string = ""){
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|