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

71 lines
2.3 KiB
TypeScript
Raw Normal View History

///<reference path="../../../browser.d.ts"/>
2016-05-04 17:20:21 +02:00
import {Component} from "@angular/core";
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";
@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> = [];
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-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();
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);
}else{
2016-05-04 18:34:54 +02:00
renderItem.postText = item.text;
}
2016-05-04 18:34:54 +02:00
this.autoCompleteItems.push(renderItem);
});
}
2016-05-04 18:57:31 +02:00
public onFocusLost(event){
this.autoCompleteItems = [];
}
private emptyAutoComplete(){
this.autoCompleteItems = [];
}
}
2016-05-04 18:34:54 +02:00
class AutoCompleteRenderItem{
constructor(public preText:string = "",public highLightText:string = "", public postText:string = ""){
}
}