mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-19 17:14:57 +00:00
- Add search box to demo-shell toolbar - Initial search component to display results Refs #69
115 lines
4.1 KiB
TypeScript
115 lines
4.1 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 { Component } from 'angular2/core';
|
|
import { ControlGroup, FormBuilder, Validators } from 'angular2/common';
|
|
import { Router, RouteConfig, ROUTER_DIRECTIVES } from 'angular2/router';
|
|
import { AlfrescoAuthenticationService } from 'ng2-alfresco-login/ng2-alfresco-login';
|
|
import { MDL } from 'ng2-alfresco-core/material';
|
|
import { FilesComponent } from './components/files/files.component';
|
|
import { AlfrescoLoginComponent } from 'ng2-alfresco-login/ng2-alfresco-login';
|
|
import { AuthRouterOutlet } from './components/router/AuthRouterOutlet';
|
|
import { AlfrescoSettingsService } from 'ng2-alfresco-core/services';
|
|
import { TranslateService, TranslatePipe } from 'ng2-translate/ng2-translate';
|
|
import { UploadButtonComponent } from 'ng2-alfresco-upload/ng2-alfresco-upload';
|
|
import { DataTableDemoComponent } from './components/datatable/datatable-demo.component';
|
|
import { AlfrescoSearchComponent } from 'ng2-alfresco-search/ng2-alfresco-search';
|
|
|
|
declare var document: any;
|
|
|
|
@Component({
|
|
selector: 'my-app',
|
|
templateUrl: 'app/app.component.html',
|
|
directives: [ROUTER_DIRECTIVES, AuthRouterOutlet, MDL],
|
|
pipes: [TranslatePipe]
|
|
})
|
|
@RouteConfig([
|
|
{path: '/home', name: 'Home', component: FilesComponent},
|
|
{path: '/', name: 'Files', component: FilesComponent, useAsDefault: true},
|
|
{path: '/datatable', name: 'DataTable', component: DataTableDemoComponent},
|
|
{path: '/uploader', name: 'Uploader', component: UploadButtonComponent},
|
|
{path: '/login', name: 'Login', component: AlfrescoLoginComponent},
|
|
{path: '/search', name: 'Search', component: AlfrescoSearchComponent}
|
|
])
|
|
export class AppComponent {
|
|
translate: TranslateService;
|
|
searchForm: ControlGroup;
|
|
|
|
constructor(private _fb: FormBuilder,
|
|
public auth: AlfrescoAuthenticationService,
|
|
public router: Router,
|
|
translate: TranslateService,
|
|
alfrescoSettingsService: AlfrescoSettingsService) {
|
|
alfrescoSettingsService.host = 'http://192.168.99.100:8080';
|
|
|
|
this.searchForm = this._fb.group({
|
|
searchTerm: ['', Validators.compose([Validators.required, Validators.minLength(3)])]
|
|
});
|
|
|
|
this.translationInit(translate);
|
|
}
|
|
|
|
isActive(instruction: any[]): boolean {
|
|
return this.router.isRouteActive(this.router.generate(instruction));
|
|
}
|
|
|
|
isLoggedIn(): boolean {
|
|
return this.auth.isLoggedIn();
|
|
}
|
|
|
|
onLogout(event) {
|
|
event.preventDefault();
|
|
this.auth.logout()
|
|
.subscribe(
|
|
() => this.router.navigate(['Login'])
|
|
);
|
|
}
|
|
|
|
changeLanguage(lang: string) {
|
|
this.translate.use(lang);
|
|
}
|
|
|
|
translationInit(translate: TranslateService) {
|
|
this.translate = translate;
|
|
let userLang = navigator.language.split('-')[0]; // use navigator lang if available
|
|
userLang = /(fr|en)/gi.test(userLang) ? userLang : 'en';
|
|
|
|
this.translate.setDefaultLang('en');
|
|
|
|
this.translate.currentLoader.addComponentList('');
|
|
this.translate.getTranslation(userLang);
|
|
this.translate.use(userLang);
|
|
}
|
|
|
|
hideDrawer() {
|
|
// todo: workaround for drawer closing
|
|
document.querySelector('.mdl-layout').MaterialLayout.toggleDrawer();
|
|
}
|
|
|
|
/**
|
|
* Method called on submit form
|
|
* @param value
|
|
* @param event
|
|
*/
|
|
onSearch(value: any, event) {
|
|
if (event) {
|
|
event.preventDefault();
|
|
}
|
|
this.router.navigate(['Search', value]);
|
|
}
|
|
}
|