2017-12-19 13:53:46 +01:00
import { Component , Input , Output , ElementRef , EventEmitter , ViewChild } from '@angular/core' ;
import { Observable } from 'rxjs/Observable' ;
import { SearchProjectsService } from '../../services/searchProjects.service' ;
import { ProjectService } from '../../landingPages/project/project.service' ;
// import {ModalLoading} from '../../utils/modal/loading.component';
import { Subject } from 'rxjs/Subject' ;
import { ClaimProject } from './claimEntities.class' ;
declare var UIkit :any ;
2018-02-05 14:14:59 +01:00
import { EnvProperties } from '../../utils/properties/env-properties' ;
2017-12-19 13:53:46 +01:00
@Component ( {
selector : 'claim-projects-search-form' ,
template : `
2018-07-25 15:56:02 +02:00
< form [ class ] = " ( ( inlineClaim ) ? ' ' : ' uk - card uk - card - default uk - padding uk - padding - medium ' ) + ' uk - animation ' " >
< div class = "uk-text-lead" > Search for projects < helper div = "link-project-form" tooltip = true > < / helper > < / div >
2018-02-15 11:36:12 +01:00
< div class = "uk-grid" >
< div class = "uk-grid uk-width-expand" >
< div class = "uk-width-auto@m uk-first-column" >
< select class = "uk-select uk-width-large" [ ( ngModel ) ] = " selectedFunderId " name = "select_funder" >
< option value = "0" ( click ) = " funderChanged ( ' 0 ' , ' Select funder : ' ) " > Select funder : < / option >
< option * ngFor = "let funder of funders" [ value ] = " funder.id " ( click ) = " funderChanged ( funder.id , funder.name ) " > { { ( funder . name . split ( "||" ) . length > 0 ) ? ( funder . name . split ( "||" ) [ 0 ] + " (" + funder . name . split ( "||" ) [ 1 ] + ")" ) : ( funder . name ) } } < / option >
< / select >
< / div >
< div class = "uk-width-expand@m" >
< entities - autocomplete [ ( properties ) ] = properties entityType = "project" [ funderId ] = " selectedFunderId " [ allowDuplicates ] = true [ showSelected ] = false [ placeHolderMessage ] = " ' Project name or ID ' " title = "Projects" [ multipleSelections ] = true ( addItem ) = " select ( $ event ) " > < / e n t i t i e s - a u t o c o m p l e t e >
< / div >
2017-12-19 13:53:46 +01:00
< / div >
2018-07-25 15:56:02 +02:00
2018-02-15 11:36:12 +01:00
< / div >
< / form >
2017-12-19 13:53:46 +01:00
`
} )
export class ClaimProjectsSearchFormComponent {
ngOnInit() {
this . getFunders ( ) ;
}
// @ViewChild (ModalLoading) loading : ModalLoading ;
// @Input() public inline: boolean = false ; // for claimed started from landing pages
public query = '' ;
@Input ( ) public selectedProjects = [ ] ;
public elementRef ;
public funders :string [ ] ;
public selectedFunderId :string = "0" ;
selectedFunderName :string = "Select funder:" ;
@Output ( ) projectSelected = new EventEmitter ( ) ;
2018-02-05 14:14:59 +01:00
@Input ( ) public properties :EnvProperties ;
2018-07-25 15:56:02 +02:00
@Input ( ) public inlineClaim :boolean = false ;
@Input ( ) localStoragePrefix :string = "" ;
2017-12-19 13:53:46 +01:00
public projects :string [ ] ;
public warningMessage = "" ;
public infoMessage = "" ;
// public searchTermStream = new Subject<string>();
// filtered: Observable<{}> = this.searchTermStream
// .debounceTime(300).distinctUntilChanged()
// .switchMap((term: string) => this._projectService.searchForProjectsObs(term, this.selectedFunderId));
public tries :number = 0 ;
public keywordlimit = 3 ;
constructor ( private _service : ProjectService , private _projectService : SearchProjectsService , myElement : ElementRef ) {
this . elementRef = myElement ;
}
// search() {
// console.info("heeere "+this.query );
// this.infoMessage = "";
// // this.filtered = [];
// if(this.query == ""){
// this.tries = 0;
// this.warningMessage = "";
// } else if(this.query && this.query.length < this.keywordlimit){
// this.tries++;
// if(this.tries == this.keywordlimit -1 ){
// this.warningMessage = "Type at least " + this.keywordlimit + " characters";
// this.tries = 0;
// }
// }else{
// console.info("doo the search "+this.query );
//
// this.tries = 0;
// this.warningMessage = "";
// this.searchTermStream.next(this.query);
//
// }
//
// }
select ( item ) {
2018-11-12 16:36:20 +01:00
if ( this . selectedProjects . length > 50 ) {
UIkit . notification ( {
message : 'Your basket exceeds the number of allowed projects (50)' ,
status : 'warning' ,
timeout : 1500 ,
pos : 'top-center'
} ) ;
return ;
}
2017-12-19 13:53:46 +01:00
this . query = "" ;
// this.searchTermStream.next(this.query); //clear
item = item . value ;
var project : ClaimProject = new ClaimProject ( ) ;
2019-02-28 17:32:29 +01:00
project . funderId = item . funderId ;
project . funderName = item . funderName ;
2017-12-19 13:53:46 +01:00
project . projectId = item . id ;
project . projectName = item . projectName ;
project . projectAcronym = item . projectAcronym ;
project . startDate = item . startDate ;
project . endDate = item . endDate ;
project . code = item . code ;
project . jurisdiction = item . jurisdiction ;
project . fundingLevel0 = item . fundingLevel0 ;
// this._service.getProjectDates(project.projectId).subscribe(
// data => {
// project.startDate = data.startDate;
// project.endDate = data.endDate;
// },
// err => console.log(err)
// );
var index :number = this . selectedProjects . indexOf ( project ) ;
var found :boolean = false ;
this . warningMessage = "" ;
for ( var _i = 0 ; _i < this . selectedProjects . length ; _i ++ ) {
let item = this . selectedProjects [ _i ] ;
if ( item . projectId == project . projectId ) {
found = true ;
2018-11-12 16:36:20 +01:00
this . warningMessage = "Project already in your basket" ;
2017-12-19 13:53:46 +01:00
}
}
if ( ! found ) {
this . selectedProjects . push ( project ) ;
2018-07-25 15:56:02 +02:00
if ( this . selectedProjects != null ) {
localStorage . setItem ( this . localStoragePrefix + "projects" , JSON . stringify ( this . selectedProjects ) ) ;
}
2017-12-19 13:53:46 +01:00
this . projectSelected . emit ( {
value : true
} ) ;
UIkit . notification ( {
2018-10-25 11:33:56 +02:00
message : 'A new project added in the basket.' ,
2017-12-19 13:53:46 +01:00
status : 'primary' ,
2018-11-12 16:36:20 +01:00
timeout : 1500 ,
2017-12-19 13:53:46 +01:00
pos : 'top-center'
} ) ;
} else {
UIkit . notification ( {
2018-11-12 16:36:20 +01:00
message : 'The project is already in your basket.' ,
2017-12-19 13:53:46 +01:00
status : 'warning' ,
2018-11-12 16:36:20 +01:00
timeout : 1500 ,
2017-12-19 13:53:46 +01:00
pos : 'top-center'
} ) ;
}
}
showItem ( item ) : string {
return ( ( item . field [ 1 ] [ '@value' ] ) ? item . field [ 1 ] [ '@value' ] + " - " : "" ) + item . field [ 3 ] [ '@value' ] ;
}
remove ( item ) {
var index :number = this . selectedProjects . indexOf ( item ) ;
if ( index > - 1 ) {
this . selectedProjects . splice ( index , 1 ) ;
}
}
handleClick ( event ) {
var clickedComponent = event . target ;
var inside = false ;
do {
if ( clickedComponent === this . elementRef . nativeElement ) {
inside = true ;
}
clickedComponent = clickedComponent . parentNode ;
} while ( clickedComponent ) ;
}
getFunders ( ) {
2018-02-05 14:14:59 +01:00
this . _projectService . getFunders ( this . properties ) . subscribe (
2017-12-19 13:53:46 +01:00
data = > {
this . funders = data [ 1 ] ;
} ,
2019-02-18 15:00:43 +01:00
err = > {
this . handleError ( "Error getting funders" , err ) ;
//console.log(err)
}
2017-12-19 13:53:46 +01:00
) ;
}
getProjects ( ) {
if ( this . selectedFunderId != '0' ) {
}
}
funderChanged ( funderId :string , funderName :string ) {
this . selectedFunderId = funderId ;
this . selectedFunderName = funderName ;
2019-02-14 11:15:44 +01:00
//console.info("Selected funder:"+this.selectedFunderId+ ' name:'+funderName );
2017-12-19 13:53:46 +01:00
}
2019-02-18 15:00:43 +01:00
private handleError ( message : string , error ) {
console . error ( "Claim project search form (component): " + message , error ) ;
}
2017-12-19 13:53:46 +01:00
}