argos/dmp-frontend/src/app/ui/description/editor/prefill-description/prefill-description.compone...

104 lines
4.3 KiB
TypeScript
Raw Normal View History

2023-11-29 14:26:40 +01:00
import { Component, Inject, OnInit } from "@angular/core";
import { UntypedFormBuilder, UntypedFormGroup, Validators } from "@angular/forms";
import { MAT_DIALOG_DATA, MatDialog, MatDialogRef } from "@angular/material/dialog";
2024-04-18 13:15:03 +02:00
import { DescriptionPrefillingRequest, PrefillingSearchRequest } from "@app/core/model/description-profiling-request/description-profiling-request";
2024-02-28 14:41:36 +01:00
import { DescriptionTemplate } from "@app/core/model/description-template/description-template";
import { Dmp } from "@app/core/model/dmp/dmp";
2024-03-05 12:41:58 +01:00
import { Prefilling } from "@app/core/model/prefilling-source/prefilling-source";
2024-03-01 17:45:32 +01:00
import { PrefillingSourceService } from "@app/core/services/prefilling-source/prefilling-source.service";
2023-11-29 14:26:40 +01:00
import { ProgressIndicationService } from "@app/core/services/progress-indication/progress-indication-service";
2024-03-05 12:41:58 +01:00
import { SingleAutoCompleteConfiguration } from "@app/library/auto-complete/single/single-auto-complete-configuration";
2023-11-29 14:26:40 +01:00
import { BaseComponent } from "@common/base/base.component";
2024-03-01 17:45:32 +01:00
import { FormService } from "@common/forms/form-service";
2023-11-29 14:26:40 +01:00
import { Guid } from "@common/types/guid";
import { TranslateService } from "@ngx-translate/core";
2024-03-05 12:41:58 +01:00
import { Observable } from "rxjs";
import { map, takeUntil } from "rxjs/operators";
2024-04-03 16:50:47 +02:00
import { DescriptionEditorResolver } from "../description-editor.resolver";
import { nameof } from "ts-simple-nameof";
import { Description } from "@app/core/model/description/description";
import { IsActive } from "@app/core/common/enum/is-active.enum";
2024-04-19 09:00:57 +02:00
import { DescriptionPrefillingRequestEditorModel } from "./prefill-description-editor.model";
2023-11-29 14:26:40 +01:00
@Component({
2024-02-28 14:41:36 +01:00
selector: 'prefill-description-component',
templateUrl: 'prefill-description.component.html',
styleUrls: ['prefill-description.component.scss']
2023-11-29 14:26:40 +01:00
})
2024-02-28 14:41:36 +01:00
export class PrefillDescriptionDialogComponent extends BaseComponent implements OnInit {
2023-11-29 14:26:40 +01:00
progressIndication = false;
2024-03-05 12:41:58 +01:00
prefillAutoCompleteConfiguration: SingleAutoCompleteConfiguration;
2024-02-28 14:41:36 +01:00
prefillSelected: boolean = false;
2023-11-29 14:26:40 +01:00
prefillForm: UntypedFormGroup;
2024-02-28 14:41:36 +01:00
dmp: Dmp;
dmpSectionId: Guid;
2024-03-01 17:45:32 +01:00
availableDescriptionTemplates: DescriptionTemplate[] = [];
2024-02-28 14:41:36 +01:00
constructor(public dialogRef: MatDialogRef<PrefillDescriptionDialogComponent>,
2023-11-29 14:26:40 +01:00
private progressIndicationService: ProgressIndicationService,
2024-03-01 17:45:32 +01:00
public prefillingSourceService: PrefillingSourceService,
private formService: FormService,
2023-11-29 14:26:40 +01:00
@Inject(MAT_DIALOG_DATA) public data: any) {
super();
2024-02-28 14:41:36 +01:00
this.dmp = data.dmp;
this.dmpSectionId = data.dmpSectionId;
2024-04-03 16:50:47 +02:00
this.availableDescriptionTemplates = this.dmp.dmpDescriptionTemplates.filter(x => x.sectionId == this.dmpSectionId && x.isActive == IsActive.Active).map(x => x.currentDescriptionTemplate);
2023-11-29 14:26:40 +01:00
}
ngOnInit() {
this.progressIndicationService.getProgressIndicationObservable().pipe(takeUntil(this._destroyed)).subscribe(x => {
setTimeout(() => { this.progressIndication = x; });
});
2024-04-19 09:00:57 +02:00
const editorModel = new DescriptionPrefillingRequestEditorModel();
this.prefillForm = editorModel.buildForm(null, false);
2024-03-05 12:41:58 +01:00
this.prefillAutoCompleteConfiguration = {
filterFn: this.searchDescriptions.bind(this),
loadDataOnStart: false,
2024-04-19 09:53:27 +02:00
displayFn: (item: Prefilling) => (item.label.length > 60) ? (item.label.substr(0, 60) + "...") : item.label,
titleFn: (item: Prefilling) => item.label,
subtitleFn: (item: Prefilling) => item.id,
valueAssign: (item: Prefilling) => item,
uniqueAssign: (item: Prefilling) => item.id,
2024-03-05 12:41:58 +01:00
};
2023-11-29 14:26:40 +01:00
}
2024-04-17 14:39:30 +02:00
changePreffillingSource(){
2024-04-18 13:15:03 +02:00
this.prefillForm.get('data').setValue(null);
2024-04-17 14:39:30 +02:00
}
2023-11-29 14:26:40 +01:00
public compareWith(object1: any, object2: any) {
return object1 && object2 && object1.id === object2.id;
}
2024-03-05 12:41:58 +01:00
searchDescriptions(query: string): Observable<Prefilling[]> {
const request: PrefillingSearchRequest= {
like: query,
prefillingSourceId: this.prefillForm.get('prefillingSourceId').value
};
2024-04-17 10:44:25 +02:00
return this.prefillingSourceService.search(request);
2024-03-05 12:41:58 +01:00
}
2023-11-29 14:26:40 +01:00
next() {
2024-04-18 13:15:03 +02:00
const formData = this.formService.getValue(this.prefillForm.value) as DescriptionPrefillingRequest;
2024-03-01 17:45:32 +01:00
2024-04-03 16:50:47 +02:00
this.prefillingSourceService.generate(formData, DescriptionEditorResolver.descriptionTemplateLookupFields(nameof<Description>(x => x.descriptionTemplate)))
2024-03-05 12:41:58 +01:00
.pipe(takeUntil(this._destroyed)).subscribe(description => {
if (description) {
this.closeDialog(description);
} else {
this.closeDialog();
}
}
2024-03-01 17:45:32 +01:00
);
2023-11-29 14:26:40 +01:00
}
closeDialog(result = null): void {
this.dialogRef.close(result);
}
2024-04-18 13:15:03 +02:00
}