2023-12-28 16:18:49 +01:00
|
|
|
import { HttpClient } from '@angular/common/http';
|
2019-03-05 12:59:34 +01:00
|
|
|
import { Component, Inject } from '@angular/core';
|
2023-12-28 16:18:49 +01:00
|
|
|
import { MAT_DIALOG_DATA, MatDialog, MatDialogRef } from '@angular/material/dialog';
|
2023-12-29 16:04:16 +01:00
|
|
|
import { DescriptionTemplate } from '@app/core/model/description-template/description-template';
|
|
|
|
import { DmpService } from '@app/core/services/dmp/dmp.service';
|
2020-12-14 18:28:13 +01:00
|
|
|
import { MatomoService } from '@app/core/services/matomo/matomo-service';
|
2023-12-28 16:18:49 +01:00
|
|
|
import { MultipleAutoCompleteConfiguration } from '@app/library/auto-complete/multiple/multiple-auto-complete-configuration';
|
|
|
|
import { BaseComponent } from '@common/base/base.component';
|
|
|
|
import { Observable } from 'rxjs';
|
|
|
|
import { map } from 'rxjs/operators';
|
2019-03-05 12:59:34 +01:00
|
|
|
|
|
|
|
@Component({
|
2023-12-28 16:18:49 +01:00
|
|
|
selector: 'dmp-upload-dialog',
|
|
|
|
templateUrl: './dmp-upload-dialog.component.html',
|
|
|
|
styleUrls: ['./dmp-upload-dialog.component.scss']
|
2019-03-05 12:59:34 +01:00
|
|
|
})
|
2023-12-28 16:18:49 +01:00
|
|
|
export class DmpUploadDialogComponent extends BaseComponent {
|
2019-03-05 12:59:34 +01:00
|
|
|
dmpTitle: string;
|
2023-10-20 17:01:09 +02:00
|
|
|
dmpBlueprints: any[] = [];
|
2020-09-28 14:44:32 +02:00
|
|
|
files: File[] = [];
|
2020-05-29 12:39:18 +02:00
|
|
|
|
|
|
|
profilesAutoCompleteConfiguration: MultipleAutoCompleteConfiguration = {
|
|
|
|
filterFn: this.filterProfiles.bind(this),
|
|
|
|
initialItems: (excludedItems: any[]) => this.filterProfiles('').pipe(map(result => result.filter(resultItem => (excludedItems || []).map(x => x.id).indexOf(resultItem.id) === -1))),
|
|
|
|
displayFn: (item) => item['label'],
|
|
|
|
titleFn: (item) => item['label'],
|
2020-10-20 12:23:22 +02:00
|
|
|
subtitleFn: (item) => item['description'],
|
|
|
|
popupItemActionIcon: 'visibility'
|
2020-05-29 12:39:18 +02:00
|
|
|
};
|
2019-03-05 12:59:34 +01:00
|
|
|
|
|
|
|
|
|
|
|
constructor(
|
2023-12-28 16:18:49 +01:00
|
|
|
public dialogRef: MatDialogRef<DmpUploadDialogComponent>,
|
2020-05-29 12:39:18 +02:00
|
|
|
private _service: DmpService,
|
2020-10-27 11:04:11 +01:00
|
|
|
private dialog: MatDialog,
|
2020-12-14 18:28:13 +01:00
|
|
|
private httpClient: HttpClient,
|
|
|
|
private matomoService: MatomoService,
|
2019-03-05 12:59:34 +01:00
|
|
|
@Inject(MAT_DIALOG_DATA) public data: any,
|
2020-10-27 11:04:11 +01:00
|
|
|
) {
|
|
|
|
super();
|
|
|
|
}
|
2019-03-05 12:59:34 +01:00
|
|
|
|
2020-12-14 18:28:13 +01:00
|
|
|
ngOnInit() {
|
|
|
|
this.matomoService.trackPageView('DMP Upload Dialog');
|
|
|
|
}
|
|
|
|
|
2019-03-05 12:59:34 +01:00
|
|
|
cancel() {
|
|
|
|
this.data.success = false;
|
|
|
|
this.dialogRef.close(this.data);
|
|
|
|
}
|
|
|
|
|
2020-09-28 14:44:32 +02:00
|
|
|
close() {
|
|
|
|
this.dialogRef.close(false);
|
|
|
|
}
|
|
|
|
|
2019-03-05 12:59:34 +01:00
|
|
|
confirm() {
|
|
|
|
this.data.success = true;
|
|
|
|
this.data.dmpTitle = this.dmpTitle;
|
2023-10-20 17:01:09 +02:00
|
|
|
this.data.dmpBlueprints = this.dmpBlueprints;
|
2019-03-05 12:59:34 +01:00
|
|
|
this.dialogRef.close(this.data);
|
|
|
|
}
|
|
|
|
|
|
|
|
uploadFile(event) {
|
|
|
|
const fileList: FileList = event.target.files
|
|
|
|
this.data.fileList = fileList;
|
|
|
|
if (this.data.fileList.length > 0) {
|
|
|
|
this.dmpTitle = fileList.item(0).name;
|
|
|
|
}
|
2023-12-28 16:18:49 +01:00
|
|
|
if (this.files.length === 1) {
|
2020-09-28 14:44:32 +02:00
|
|
|
this.files.splice(0, 1);
|
|
|
|
}
|
|
|
|
this.files.push(...event.target.files);
|
2019-03-05 12:59:34 +01:00
|
|
|
}
|
2020-05-29 12:39:18 +02:00
|
|
|
|
2020-09-28 14:44:32 +02:00
|
|
|
selectFile(event) {
|
|
|
|
const fileList: FileList = event.addedFiles
|
|
|
|
this.data.fileList = fileList;
|
|
|
|
if (this.data.fileList.length > 0) {
|
|
|
|
this.dmpTitle = fileList[0].name;
|
|
|
|
}
|
2023-12-28 16:18:49 +01:00
|
|
|
if (this.files.length === 1) {
|
2020-09-28 14:44:32 +02:00
|
|
|
this.files.splice(0, 1);
|
|
|
|
}
|
|
|
|
this.files.push(...event.addedFiles);
|
|
|
|
}
|
2020-05-29 12:39:18 +02:00
|
|
|
|
2020-09-28 14:44:32 +02:00
|
|
|
onRemove(event) {
|
|
|
|
this.files.splice(0, 1);
|
|
|
|
this.dmpTitle = null;
|
|
|
|
}
|
|
|
|
|
2023-12-29 16:04:16 +01:00
|
|
|
filterProfiles(value: string): Observable<DescriptionTemplate[]> {
|
|
|
|
// TODO refactor
|
|
|
|
// const request = new DataTableRequest<DatasetProfileCriteria>(null, null, { fields: ['+label'] });
|
|
|
|
// const criteria = new DatasetProfileCriteria();
|
|
|
|
// criteria.like = value;
|
|
|
|
// request.criteria = criteria;
|
|
|
|
// return this._service.searchDmpBlueprints(request);
|
|
|
|
return null;
|
2020-05-29 12:39:18 +02:00
|
|
|
}
|
2020-11-18 15:23:16 +01:00
|
|
|
|
|
|
|
hasFile(): boolean {
|
|
|
|
return this.files && this.files.length > 0;
|
|
|
|
}
|
2019-03-05 12:59:34 +01:00
|
|
|
}
|