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

71 lines
2.2 KiB
TypeScript
Raw Normal View History

2018-11-27 18:33:17 +01:00
import { Component, Inject, OnInit } from '@angular/core';
import { FormGroup } from '@angular/forms';
import { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material';
import { ActivatedRoute, Router } from '@angular/router';
import { takeUntil } from 'rxjs/operators';
import { BaseComponent } from '../../../core/common/base/base.component';
2018-05-28 11:50:42 +02:00
import { UserInvitationCriteria } from '../../../models/criteria/invitation/UserInvitationCriteria';
import { RequestItem } from '../../../models/criteria/RequestItem';
import { Invitation } from '../../../models/invitation/Invitation';
import { User } from '../../../models/invitation/User';
2018-11-27 18:33:17 +01:00
import { InvitationService } from '../../../services/invitation/invitation.service';
import { JsonSerializer } from '../../../utilities/JsonSerializer';
2018-05-28 11:50:42 +02:00
@Component({
2018-11-27 18:33:17 +01:00
selector: 'app-invitation-component',
templateUrl: 'invitation.component.html',
2018-05-28 11:50:42 +02:00
})
2018-11-27 18:33:17 +01:00
export class InvitationComponent extends BaseComponent implements OnInit {
2018-05-28 11:50:42 +02:00
2018-11-27 18:33:17 +01:00
public formGroup: FormGroup;
2018-05-28 11:50:42 +02:00
2018-11-27 18:33:17 +01:00
public filteredUsersAsync = false;
2018-05-28 11:50:42 +02:00
2018-11-27 18:33:17 +01:00
public filteredUsers: User[];
2018-05-28 11:50:42 +02:00
2018-11-27 18:33:17 +01:00
constructor(
public invitationService: InvitationService,
public route: ActivatedRoute,
public router: Router,
public dialogRef: MatDialogRef<InvitationComponent>,
@Inject(MAT_DIALOG_DATA) public data: any
) { super(); }
2018-05-28 11:50:42 +02:00
2018-11-27 18:33:17 +01:00
ngOnInit(): void {
const invitation = new Invitation();
invitation.dataManagementPlan = this.data.dmpId;
this.formGroup = invitation.buildForm();
}
2018-05-28 11:50:42 +02:00
2018-11-27 18:33:17 +01:00
send(value: any) {
this.invitationService.inviteUsers(this.formGroup.value)
.pipe(takeUntil(this._destroyed))
.subscribe(
null, null, () => this.dialogRef.close()
);
}
2018-05-28 11:50:42 +02:00
2018-11-27 18:33:17 +01:00
filterUsers(value: string): void {
this.filteredUsers = undefined;
if (value) {
this.filteredUsersAsync = true;
const request = new RequestItem<UserInvitationCriteria>();
request.criteria = { like: value };
this.invitationService.getUsers(request)
.pipe(takeUntil(this._destroyed))
.subscribe(items => {
this.filteredUsers = JsonSerializer.fromJSONArray(items, User);
if (!this.filteredUsers || this.filteredUsers.length === 0) {
const user = new User();
user.email = value;
user.name = value;
this.filteredUsers.push(user);
}
this.filteredUsersAsync = false;
});
2018-10-05 17:00:54 +02:00
}
}
2018-05-28 11:50:42 +02:00
}