argos/dmp-frontend/src/app/shared/components/criteria/data-management-plan/dmp-criteria.component.ts

84 lines
3.5 KiB
TypeScript
Raw Normal View History

2017-12-14 18:13:28 +01:00
import { TranslateService } from '@ngx-translate/core';
2018-03-21 14:15:06 +01:00
import { Component, OnInit, Input } from '@angular/core';
2017-12-14 18:13:28 +01:00
import { FormControl, FormGroup, FormBuilder, Validators } from '@angular/forms';
import { BaseCriteriaComponent } from '../base/base-criteria.component';
import { ValidationContext, Validation } from '../../../../utilities/validators/ValidationContext';
import { BackendErrorValidator } from '../../../../utilities/validators/BackendErrorValidator';
import { DataManagementPlanCriteria } from '../../../../models/criteria/data-management-plan/DataManagementPlanCriteria';
import { DataManagementPlanCriteriaErrorModel } from '../../../../models/criteria/data-management-plan/DataManagementPlanCriteriaErrorModel';
2017-12-19 08:31:02 +01:00
import { ProjectModel } from '../../../../models/projects/ProjectModel';
2017-12-19 10:53:52 +01:00
import { ProjectService } from '../../../../services/project/project.service';
import { ProjectCriteria } from '../../../../models/criteria/project/ProjectCriteria';
import { RequestItem } from '../../../../models/criteria/RequestItem';
import { create } from 'domain';
2018-08-24 17:21:02 +02:00
import { MultipleAutoCompleteConfiguration } from '../../autocompletes/multiple/multiple-auto-complete-configuration';
2017-12-14 18:13:28 +01:00
@Component({
2018-05-28 11:50:42 +02:00
selector: 'app-dmp-criteria-component',
templateUrl: './dmp-criteria.component.html',
styleUrls: ['./dmp-criteria.component.scss'],
2017-12-14 18:13:28 +01:00
})
export class DataManagementPlanCriteriaComponent extends BaseCriteriaComponent implements OnInit {
2018-05-28 11:50:42 +02:00
@Input()
showProject: boolean;
filteringProjectsAsync: boolean = false;
filteredProjects: ProjectModel[];
2018-08-24 17:21:02 +02:00
projectAutoCompleteConfiguration: MultipleAutoCompleteConfiguration;
public formGroup = new FormBuilder().group({
like: new FormControl(),
projects: new FormControl()
});
2017-12-14 18:13:28 +01:00
2018-05-28 11:50:42 +02:00
constructor(
public language: TranslateService,
public projectService: ProjectService,
public formBuilder: FormBuilder
) {
super(new DataManagementPlanCriteriaErrorModel());
}
2017-12-14 18:13:28 +01:00
2018-05-28 11:50:42 +02:00
ngOnInit() {
super.ngOnInit();
2018-08-24 17:21:02 +02:00
this.projectAutoCompleteConfiguration = {
filterFn: this.filterProject.bind(this),
initialItems: (excludedItems: any[]) => this.filterProject('').map(result => result.filter(x => excludedItems.map(x => x.id).indexOf(x.id) == -1)),
displayFn: (item) => item["label"],
titleFn: (item) => item["label"],
//mapFn: (item) => new JsonSerializer<ProjectReference>().fromJSONArray(item, ProjectReference).map(item => item.toDropdownList()),
loadDataOnStart: true
};
this.formGroup.get('projects').valueChanges.subscribe(x => this.controlModified())
this.formGroup.get('like').valueChanges.subscribe(x => this.controlModified())
//if (this.criteria == null) { this.criteria = new DataManagementPlanCriteria(); }
2018-05-28 11:50:42 +02:00
}
2017-12-14 18:13:28 +01:00
2018-05-28 11:50:42 +02:00
setCriteria(criteria: DataManagementPlanCriteria): void {
2018-08-24 17:21:02 +02:00
this.formGroup.get('like').patchValue(criteria.like)
this.formGroup.get('projects').patchValue(criteria.projects)
2018-05-28 11:50:42 +02:00
}
2017-12-19 10:53:52 +01:00
2018-05-28 11:50:42 +02:00
onCallbackError(error: any) {
this.setErrorModel(error.error);
}
2017-12-19 10:53:52 +01:00
2018-05-28 11:50:42 +02:00
controlModified(): void {
this.clearErrorModel();
if (this.refreshCallback != null &&
2018-08-24 17:21:02 +02:00
(this.formGroup.get('like').value == null || this.formGroup.get('like').value.length == 0 || this.formGroup.get('like').value.length > 2)
2018-05-28 11:50:42 +02:00
) {
this.refreshCallback();
}
}
2017-12-19 10:53:52 +01:00
2018-08-24 17:21:02 +02:00
filterProject(query: string) {
let projectRequestItem: RequestItem<ProjectCriteria> = new RequestItem();
projectRequestItem.criteria = new ProjectCriteria();
projectRequestItem.criteria.like = query;
return this.projectService.getWithExternal(projectRequestItem);
2018-05-28 11:50:42 +02:00
}
2017-12-14 18:13:28 +01:00
}