mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-26 17:24:56 +00:00
179 lines
5.0 KiB
TypeScript
179 lines
5.0 KiB
TypeScript
/*!
|
|
* @license
|
|
* Copyright 2016 Alfresco Software, Ltd.
|
|
*
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
* you may not use this file except in compliance with the License.
|
|
* You may obtain a copy of the License at
|
|
*
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
*
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
* See the License for the specific language governing permissions and
|
|
* limitations under the License.
|
|
*/
|
|
|
|
import { AuthenticationService, ThumbnailService } from '@alfresco/adf-core';
|
|
import { animate, state, style, transition, trigger } from '@angular/animations';
|
|
import { Component, EventEmitter, Input, OnDestroy, OnInit, Output } from '@angular/core';
|
|
import { MinimalNodeEntity } from 'alfresco-js-api';
|
|
import { Observable } from 'rxjs/Observable';
|
|
import { Subject } from 'rxjs/Subject';
|
|
|
|
@Component({
|
|
selector: 'adf-search-control',
|
|
templateUrl: './search-control.component.html',
|
|
styleUrls: ['./search-control.component.scss'],
|
|
animations: [
|
|
trigger('transitionMessages', [
|
|
state('active', style({transform: 'translateX(0%)'})),
|
|
state('inactive', style({transform: 'translateX(83%)', overflow: 'hidden'})),
|
|
state('no-animation', style({transform: 'translateX(0%)', width: '100%'})),
|
|
transition('inactive => active',
|
|
animate('300ms cubic-bezier(0.55, 0, 0.55, 0.2)')),
|
|
transition('active => inactive',
|
|
animate('300ms cubic-bezier(0.55, 0, 0.55, 0.2)'))
|
|
])
|
|
]
|
|
})
|
|
export class SearchControlComponent implements OnInit, OnDestroy {
|
|
|
|
@Input()
|
|
expandable: boolean = true;
|
|
|
|
@Input()
|
|
highlight: boolean = false;
|
|
|
|
@Input()
|
|
inputType: string = 'text';
|
|
|
|
@Input()
|
|
autocomplete: boolean = false;
|
|
|
|
@Input()
|
|
liveSearchEnabled: boolean = true;
|
|
|
|
@Input()
|
|
liveSearchRoot: string = '-root-';
|
|
|
|
@Input()
|
|
liveSearchResultType: string = null;
|
|
|
|
@Input()
|
|
liveSearchResultSort: string = null;
|
|
|
|
@Input()
|
|
liveSearchMaxResults: number = 5;
|
|
|
|
@Output()
|
|
submit: EventEmitter<any> = new EventEmitter();
|
|
|
|
@Output()
|
|
searchChange: EventEmitter<string> = new EventEmitter();
|
|
|
|
@Output()
|
|
optionClicked: EventEmitter<any> = new EventEmitter();
|
|
|
|
searchTerm: string = '';
|
|
subscriptAnimationState: string;
|
|
|
|
private toggleSearch = new Subject<any>();
|
|
private focusSubject = new Subject<FocusEvent>();
|
|
|
|
constructor(public authService: AuthenticationService,
|
|
private thumbnailService: ThumbnailService) {
|
|
|
|
this.toggleSearch.asObservable().debounceTime(100).subscribe(() => {
|
|
if (this.expandable) {
|
|
this.subscriptAnimationState = this.subscriptAnimationState === 'inactive' ? 'active' : 'inactive';
|
|
|
|
if (this.subscriptAnimationState === 'inactive') {
|
|
this.searchTerm = '';
|
|
}
|
|
}
|
|
});
|
|
}
|
|
|
|
ngOnInit() {
|
|
this.subscriptAnimationState = this.expandable ? 'inactive' : 'no-animation';
|
|
this.setupFocusEventHandlers();
|
|
}
|
|
|
|
ngOnDestroy(): void {
|
|
this.focusSubject.unsubscribe();
|
|
this.toggleSearch.unsubscribe();
|
|
}
|
|
|
|
isLoggedIn(): boolean {
|
|
return this.authService.isLoggedIn();
|
|
}
|
|
|
|
searchSubmit(event: any) {
|
|
this.submit.emit(event);
|
|
this.toggleSearchBar();
|
|
}
|
|
|
|
inputChange(event: any) {
|
|
this.searchChange.emit(event);
|
|
}
|
|
|
|
getAutoComplete(): string {
|
|
return this.autocomplete ? 'on' : 'off';
|
|
}
|
|
|
|
getMimeTypeIcon(node: MinimalNodeEntity): string {
|
|
let mimeType;
|
|
|
|
if (node.entry.content && node.entry.content.mimeType) {
|
|
mimeType = node.entry.content.mimeType;
|
|
}
|
|
if (node.entry.isFolder) {
|
|
mimeType = 'folder';
|
|
}
|
|
|
|
return this.thumbnailService.getMimeTypeIcon(mimeType);
|
|
}
|
|
|
|
isSearchBarActive() {
|
|
return this.subscriptAnimationState === 'active' && this.liveSearchEnabled;
|
|
}
|
|
|
|
toggleSearchBar() {
|
|
this.toggleSearch.next();
|
|
}
|
|
|
|
elementClicked(item: any) {
|
|
if (item.entry) {
|
|
this.optionClicked.next(item);
|
|
this.toggleSearchBar();
|
|
}
|
|
}
|
|
|
|
onFocus($event): void {
|
|
this.focusSubject.next($event);
|
|
}
|
|
|
|
onBlur($event): void {
|
|
this.focusSubject.next($event);
|
|
}
|
|
|
|
activateToolbar($event) {
|
|
if ( !this.isSearchBarActive() ) {
|
|
this.toggleSearchBar();
|
|
}
|
|
}
|
|
|
|
private setupFocusEventHandlers() {
|
|
let focusEvents: Observable<FocusEvent> = this.focusSubject.asObservable()
|
|
.distinctUntilChanged().debounceTime(50);
|
|
focusEvents.filter(($event: any) => {
|
|
return this.isSearchBarActive() && ($event.type === 'blur' || $event.type === 'focusout');
|
|
}).subscribe(() => {
|
|
this.toggleSearchBar();
|
|
});
|
|
}
|
|
|
|
}
|