argos/dmp-frontend/src/app/ui/dmp/invitation/dialog/dmp-invitation-dialog.compo...

88 lines
3.2 KiB
TypeScript
Raw Normal View History

import { COMMA, ENTER } from '@angular/cdk/keycodes';
2023-12-29 16:04:16 +01:00
import { Component, Inject, OnInit } from '@angular/core';
2023-10-05 15:39:17 +02:00
import { UntypedFormGroup } from '@angular/forms';
2023-10-06 10:10:53 +02:00
import { MAT_DIALOG_DATA, MatDialogRef } from '@angular/material/dialog';
import { ActivatedRoute, Router } from '@angular/router';
2023-12-29 16:04:16 +01:00
import { DmpUserRole } from '@app/core/common/enum/dmp-user-role';
import { DmpUserPersist } from '@app/core/model/dmp/dmp';
2023-12-29 17:36:02 +01:00
import { DmpService } from '@app/core/services/dmp/dmp.service';
2023-12-29 16:04:16 +01:00
import { SnackBarNotificationLevel, UiNotificationService } from '@app/core/services/notification/ui-notification-service';
2023-12-29 17:36:02 +01:00
import { UserService } from '@app/core/services/user/user.service';
2023-12-29 16:04:16 +01:00
import { EnumUtils } from '@app/core/services/utilities/enum-utils.service';
import { BaseComponent } from '@common/base/base.component';
2023-12-29 17:36:02 +01:00
import { FilterService } from '@common/modules/text-filter/filter-service';
import { Guid } from '@common/types/guid';
2023-12-29 16:04:16 +01:00
import { TranslateService } from '@ngx-translate/core';
import { DmpEditorModel } from '../../dmp-editor-blueprint/dmp-editor.model';
import { takeUntil } from 'rxjs/operators';
import { DmpBlueprint } from '@app/core/model/dmp-blueprint/dmp-blueprint';
@Component({
selector: 'app-invitation-dialog-component',
templateUrl: 'dmp-invitation-dialog.component.html',
styleUrls: ['./dmp-invitation-dialog.component.scss'],
})
export class DmpInvitationDialogComponent extends BaseComponent implements OnInit {
2023-12-29 17:36:02 +01:00
dmpId: Guid;
editorModel: DmpEditorModel;
2023-12-29 17:36:02 +01:00
formGroup: UntypedFormGroup;
dmpUserRoleEnum = DmpUserRole;
selectedBlueprint: DmpBlueprint;
readonly separatorKeysCodes: number[] = [ENTER, COMMA];
2023-12-29 17:36:02 +01:00
constructor(
public enumUtils: EnumUtils,
public route: ActivatedRoute,
public router: Router,
private language: TranslateService,
public dialogRef: MatDialogRef<DmpInvitationDialogComponent>,
private uiNotificationService: UiNotificationService,
private dmpService: DmpService,
private userService: UserService,
private filterService: FilterService,
@Inject(MAT_DIALOG_DATA) public data: any
) {
super();
this.dmpId = data.dmpId;
this.editorModel = data ? new DmpEditorModel().fromModel(data) : new DmpEditorModel();
this.selectedBlueprint = data?.blueprint;
}
2023-12-29 17:36:02 +01:00
ngOnInit() {
this.formGroup = this.editorModel.buildForm();
}
2023-12-29 17:36:02 +01:00
send() {
if (!this.formGroup.get("users").valid) { return; }
const userFormData = this.formGroup.get("users").value as DmpUserPersist[];
2023-12-29 17:36:02 +01:00
this.dmpService.inviteUsers(this.dmpId, {users: userFormData})
2023-12-29 17:36:02 +01:00
.pipe(takeUntil(this._destroyed))
.subscribe(
complete => {
this.dialogRef.close();
this.onCallbackSuccess();
},
error => this.onCallbackError(error)
);
}
closeDialog(): void {
this.dialogRef.close();
}
2020-09-29 13:18:46 +02:00
hasValue(): boolean {
return this.formGroup.get('users') && this.formGroup.get('users').value && this.formGroup.get('users').value.length > 0;
}
onCallbackSuccess(): void {
2024-03-27 16:21:28 +01:00
this.uiNotificationService.snackBarNotification(this.language.instant('DMP-USER-INVITATION-DIALOG.SUCCESS'), SnackBarNotificationLevel.Success);
}
onCallbackError(errorResponse: any) {
2024-03-27 16:21:28 +01:00
this.uiNotificationService.snackBarNotification(this.language.instant('DMP-USER-INVITATION-DIALOG.ERROR'), SnackBarNotificationLevel.Error);
}
}