argos/dmp-frontend/src/app/shared/components/criteria/datasets/datasets-criteria.component.ts

82 lines
2.5 KiB
TypeScript
Raw Normal View History

2018-11-27 18:33:17 +01:00
import { Component, OnInit } from '@angular/core';
import { FormBuilder } from '@angular/forms';
2017-12-18 12:26:13 +01:00
import { TranslateService } from '@ngx-translate/core';
2018-11-27 18:33:17 +01:00
import { takeUntil } from 'rxjs/operators';
2017-12-18 12:26:13 +01:00
import { DatasetCriteria } from '../../../../models/criteria/dataset/DatasetCriteria';
2018-11-27 18:33:17 +01:00
import { DatasetCriteriaErrorModel } from '../../../../models/criteria/dataset/DatasetCriteriaErrorModel';
2018-07-11 15:47:36 +02:00
import { RequestItem } from '../../../../models/criteria/RequestItem';
2018-11-27 18:33:17 +01:00
import { TagsCriteria } from '../../../../models/criteria/tags/TagsCriteria';
2018-07-11 15:47:36 +02:00
import { ExternalSourcesItemModel } from '../../../../models/external-sources/ExternalSourcesItemModel';
2018-11-27 18:33:17 +01:00
import { ExternalSourcesService } from '../../../../services/external-sources/external-sources.service';
import { BaseCriteriaComponent } from '../base/base-criteria.component';
2017-12-18 12:26:13 +01:00
@Component({
2018-10-05 17:00:54 +02:00
selector: 'app-datasets-criteria-component',
templateUrl: './datasets-criteria.component.html',
styleUrls: ['./datasets-criteria.component.scss'],
providers: [
ExternalSourcesService
]
2017-12-18 12:26:13 +01:00
})
export class DatasetCriteriaComponent extends BaseCriteriaComponent implements OnInit {
2018-10-05 17:00:54 +02:00
public criteria: any;
public filteringTagsAsync = false;
public filteredTags: ExternalSourcesItemModel[];
2018-07-11 15:47:36 +02:00
2018-10-05 17:00:54 +02:00
statuses = [
{ value: '0', viewValue: 'Draft' },
{ value: '1', viewValue: 'Finalised' }
];
2018-07-11 15:47:36 +02:00
2018-10-05 17:00:54 +02:00
constructor(
public language: TranslateService,
public formBuilder: FormBuilder,
public externalSourcesService: ExternalSourcesService
) {
super(new DatasetCriteriaErrorModel());
}
2018-07-11 15:47:36 +02:00
2018-10-05 17:00:54 +02:00
ngOnInit() {
super.ngOnInit();
if (this.criteria == null) { this.criteria = {}; }
}
2018-07-11 15:47:36 +02:00
2018-10-05 17:00:54 +02:00
setCriteria(criteria: DatasetCriteria): void {
this.criteria = criteria;
}
2018-07-11 15:47:36 +02:00
2018-10-05 17:00:54 +02:00
onCallbackError(error: any) {
this.setErrorModel(error.error);
}
2018-07-11 15:47:36 +02:00
2018-10-05 17:00:54 +02:00
controlModified(): void {
this.clearErrorModel();
if (this.refreshCallback != null &&
(this.criteria.like == null || this.criteria.like.length === 0 || this.criteria.like.length > 2)
) {
this.refreshCallback();
}
}
2018-07-11 15:47:36 +02:00
2018-10-05 17:00:54 +02:00
filterTags(value: string): void {
2018-07-11 15:47:36 +02:00
2018-10-05 17:00:54 +02:00
this.filteredTags = undefined;
if (value) {
this.filteringTagsAsync = true;
2018-07-11 15:47:36 +02:00
2018-10-05 17:00:54 +02:00
const requestItem: RequestItem<TagsCriteria> = new RequestItem();
const criteria: TagsCriteria = new TagsCriteria();
criteria.like = value;
requestItem.criteria = criteria;
2018-11-27 18:33:17 +01:00
this.externalSourcesService.searchDatasetTags(requestItem)
.pipe(takeUntil(this._destroyed))
.subscribe(items => {
this.filteredTags = items;
this.filteringTagsAsync = false;
});
2018-10-05 17:00:54 +02:00
}
}
2017-12-18 12:26:13 +01:00
}