argos/dmp-frontend/src/app/ui/dmp/listing/criteria/dmp-criteria.component.ts

193 lines
8.2 KiB
TypeScript
Raw Normal View History

2019-09-23 10:17:03 +02:00
import {map, takeUntil } from 'rxjs/operators';
2018-11-27 18:33:17 +01:00
import { Component, Input, OnInit } from '@angular/core';
2019-05-17 09:44:16 +02:00
import { FormBuilder, FormControl } from '@angular/forms';
2019-09-23 10:17:03 +02:00
import { MatDialog } from '@angular/material/dialog';
2017-12-14 18:13:28 +01:00
import { TranslateService } from '@ngx-translate/core';
2019-01-18 18:03:45 +01:00
import { ValidationErrorModel } from '../../../../common/forms/validation/error-model/validation-error-model';
2019-05-17 09:44:16 +02:00
import { DataTableRequest } from '../../../../core/model/data-table/data-table-request';
import { GrantListingModel } from '../../../../core/model/grant/grant-listing';
2019-01-18 18:03:45 +01:00
import { DmpCriteria } from '../../../../core/query/dmp/dmp-criteria';
2019-05-17 09:44:16 +02:00
import { OrganisationCriteria } from '../../../../core/query/organisation/organisation-criteria';
import { GrantCriteria } from '../../../../core/query/grant/grant-criteria';
2019-05-17 09:44:16 +02:00
import { UserCriteria } from '../../../../core/query/user/user-criteria';
import { DmpService } from '../../../../core/services/dmp/dmp.service';
import { OrganisationService } from '../../../../core/services/organisation/organisation.service';
import { GrantService } from '../../../../core/services/grant/grant.service';
2019-05-17 09:44:16 +02:00
import { UserService } from '../../../../core/services/user/user.service';
2019-01-18 18:03:45 +01:00
import { MultipleAutoCompleteConfiguration } from '../../../../library/auto-complete/multiple/multiple-auto-complete-configuration';
import { BaseCriteriaComponent } from '../../../misc/criteria/base-criteria.component';
2019-03-05 12:59:34 +01:00
import { DmpUploadDialogue } from './upload-dialogue/dmp-upload-dialogue.component';
import { DatasetProfileCriteria } from '../../../../core/query/dataset-profile/dataset-profile-criteria';
import { DatasetProfileService } from '../../../../core/services/dataset-profile/dataset-profile.service';
2017-12-14 18:13:28 +01:00
@Component({
2018-10-05 17:00:54 +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
})
2019-01-18 18:03:45 +01:00
export class DmpCriteriaComponent extends BaseCriteriaComponent implements OnInit {
2017-12-14 18:13:28 +01:00
@Input() showGrant: boolean;
filteringGrantsAsync = false;
2019-03-05 12:59:34 +01:00
sizeError = false;
maxFileSize: number = 1048576;
filteringOrganisationsAsync = false;
2019-05-06 12:15:45 +02:00
filteredGrants: GrantListingModel[];
2018-10-05 17:00:54 +02:00
public formGroup = new FormBuilder().group({
like: new FormControl(),
grants: new FormControl(),
status: new FormControl(),
role: new FormControl,
organisations: new FormControl(),
collaborators: new FormControl(),
datasetTemplates: new FormControl()
2018-10-05 17:00:54 +02:00
});
collaboratorsAutoCompleteConfiguration: MultipleAutoCompleteConfiguration = {
filterFn: this.filterCollaborators.bind(this),
2019-09-23 10:17:03 +02:00
initialItems: (excludedItems: any[]) => this.filterCollaborators('').pipe(map(result => result.filter(resultItem => excludedItems.map(x => x.id).indexOf(resultItem.id) === -1))),
displayFn: (item) => item['name'],
titleFn: (item) => item['name']
};
datasetTemplateAutoCompleteConfiguration: MultipleAutoCompleteConfiguration = {
filterFn: this.filterDatasetTemplate.bind(this),
2019-09-23 10:17:03 +02:00
initialItems: (excludedItems: any[]) => this.filterDatasetTemplate('').pipe(map(result => result.filter(resultItem => excludedItems.map(x => x.id).indexOf(resultItem.id) === -1))),
displayFn: (item) => item['label'],
titleFn: (item) => item['label'],
subtitleFn: (item) => item['description']
};
grantAutoCompleteConfiguration: MultipleAutoCompleteConfiguration = {
filterFn: this.filterGrant.bind(this),
2019-09-23 10:17:03 +02:00
initialItems: (excludedItems: any[]) => this.filterGrant('').pipe(map(result => result.filter(resultItem => excludedItems.map(x => x.id).indexOf(resultItem.id) === -1))),
2019-01-18 18:03:45 +01:00
displayFn: (item) => item['label'],
titleFn: (item) => item['label']
2019-01-18 18:03:45 +01:00
};
2017-12-14 18:13:28 +01:00
organisationAutoCompleteConfiguration: MultipleAutoCompleteConfiguration = {
filterFn: this.filterOrganisations.bind(this),
2019-09-23 10:17:03 +02:00
initialItems: (excludedItems: any[]) => this.filterOrganisations('').pipe(map(result => result.filter(resultItem => excludedItems.map(x => x.id).indexOf(resultItem.id) === -1))),
displayFn: (item) => item['name'],
titleFn: (item) => item['name']
}
2018-10-05 17:00:54 +02:00
constructor(
public language: TranslateService,
public grantService: GrantService,
2019-03-05 12:59:34 +01:00
private dmpService: DmpService,
public formBuilder: FormBuilder,
private dialog: MatDialog,
private organisationService: OrganisationService,
private userService: UserService,
private datasetProfileService: DatasetProfileService
2018-10-05 17:00:54 +02:00
) {
2019-01-18 18:03:45 +01:00
super(new ValidationErrorModel());
2018-10-05 17:00:54 +02:00
}
2017-12-14 18:13:28 +01:00
2018-10-05 17:00:54 +02:00
ngOnInit() {
super.ngOnInit();
this.formGroup.get('role').valueChanges
.pipe(takeUntil(this._destroyed))
.subscribe(x => this.controlModified());
this.formGroup.get('organisations').valueChanges
.pipe(takeUntil(this._destroyed))
.subscribe(x => this.controlModified());
this.formGroup.get('status').valueChanges
.pipe(takeUntil(this._destroyed))
.subscribe(x => this.controlModified());
this.formGroup.get('grants').valueChanges
2018-11-27 18:33:17 +01:00
.pipe(takeUntil(this._destroyed))
.subscribe(x => this.controlModified());
this.formGroup.get('like').valueChanges
.pipe(takeUntil(this._destroyed))
.subscribe(x => this.controlModified());
this.formGroup.get('collaborators').valueChanges
.pipe(takeUntil(this._destroyed))
.subscribe(x => this.controlModified());
this.formGroup.get('datasetTemplates').valueChanges
.pipe(takeUntil(this._destroyed))
.subscribe(x => this.controlModified());
2018-10-05 17:00:54 +02:00
//if (this.criteria == null) { this.criteria = new DataManagementPlanCriteria(); }
}
2017-12-14 18:13:28 +01:00
2019-01-18 18:03:45 +01:00
setCriteria(criteria: DmpCriteria): void {
2018-10-05 17:00:54 +02:00
this.formGroup.get('like').patchValue(criteria.like);
this.formGroup.get('grants').patchValue(criteria.grants);
this.formGroup.get('status').patchValue(criteria.status);
this.formGroup.get('role').patchValue(criteria.role);
this.formGroup.get('collaborators').patchValue(criteria.collaborators);
this.formGroup.get('datasetTemplates').patchValue(criteria.datasetTemplates);
2018-10-05 17:00:54 +02:00
}
2017-12-19 10:53:52 +01:00
2018-10-05 17:00:54 +02:00
onCallbackError(error: any) {
this.setErrorModel(error.error);
}
2017-12-19 10:53:52 +01:00
2018-10-05 17:00:54 +02:00
controlModified(): void {
this.clearErrorModel();
if (this.refreshCallback != null &&
(this.formGroup.get('like').value == null || this.formGroup.get('like').value.length === 0 || this.formGroup.get('like').value.length > 2)
) {
setTimeout(() => this.refreshCallback(true));
2018-10-05 17:00:54 +02:00
}
}
2017-12-19 10:53:52 +01:00
filterGrant(query: string) {
const fields: Array<string> = new Array<string>();
fields.push('asc');
const grantRequestItem: DataTableRequest<GrantCriteria> = new DataTableRequest(0, null, { fields: fields });
grantRequestItem.criteria = new GrantCriteria();
grantRequestItem.criteria.like = query;
2019-09-23 10:17:03 +02:00
return this.grantService.getPaged(grantRequestItem, "autocomplete").pipe(map(x => x.data));
2018-10-05 17:00:54 +02:00
}
2019-03-05 12:59:34 +01:00
filterOrganisations(value: string) {
this.filteringOrganisationsAsync = true;
const fields: Array<string> = new Array<string>();
fields.push('asc');
const dataTableRequest: DataTableRequest<OrganisationCriteria> = new DataTableRequest(0, null, { fields: fields });
dataTableRequest.criteria = new OrganisationCriteria();
dataTableRequest.criteria.labelLike = value;
2019-09-23 10:17:03 +02:00
return this.organisationService.searchInternalOrganisations(dataTableRequest).pipe(map(x => x.data));
}
filterCollaborators(query: string) {
const fields: Array<string> = new Array<string>();
fields.push('asc');
const collaboratorsRequestItem: DataTableRequest<UserCriteria> = new DataTableRequest(0, null, { fields: fields });
collaboratorsRequestItem.criteria = new UserCriteria();
collaboratorsRequestItem.criteria.collaboratorLike = query;
2019-09-23 10:17:03 +02:00
return this.userService.getCollaboratorsPaged(collaboratorsRequestItem).pipe(map(x => x.data));
}
filterDatasetTemplate(query: string) {
const fields: Array<string> = new Array<string>();
fields.push('asc');
const datasetTemplateRequestItem: DataTableRequest<DatasetProfileCriteria> = new DataTableRequest(0, null, { fields: fields });
datasetTemplateRequestItem.criteria = new DatasetProfileCriteria();
datasetTemplateRequestItem.criteria.like = query;
2019-09-23 10:17:03 +02:00
return this.dmpService.getDatasetProfilesUsedPaged(datasetTemplateRequestItem).pipe(map(x => x.data));
}
2019-03-05 12:59:34 +01:00
fileSave(event) {
const dialogRef = this.dialog.open(DmpUploadDialogue, {
data: {
fileList: FileList,
success: Boolean,
dmpTitle: String
}
});
dialogRef.afterClosed().pipe(takeUntil(this._destroyed)).subscribe(result => {
if (result && result.success) {
this.dmpService.uploadXml(result.fileList, result.dmpTitle)
.pipe(takeUntil(this._destroyed))
.subscribe();
2019-03-05 12:59:34 +01:00
}
});
}
2017-12-14 18:13:28 +01:00
}