import {AfterViewInit, ChangeDetectorRef, Component, Input, OnInit, ViewChild} from "@angular/core"; import {Role, User} from "../login/utils/helper.class"; import {ActivatedRoute, Router} from "@angular/router"; import {UserManagementService} from "../services/user-management.service"; import {UserRegistryService} from "../services/user-registry.service"; import {LoginErrorCodes} from "../login/utils/guardHelper.class"; import {Subscription} from "rxjs"; import {UntypedFormBuilder, UntypedFormControl, Validators} from "@angular/forms"; import {AlertModal} from "../utils/modal/alert"; import {properties} from "../../../environments/environment"; import {EmailService} from "../utils/email/email.service"; import {Composer} from "../utils/email/composer"; import {ClearCacheService} from "../services/clear-cache.service"; import {BaseComponent} from "../sharedComponents/base/base.component"; @Component({ selector: 'role-verification', template: `
You have been invited to join {{name}} {{(service === 'monitor' ? 'Monitor' : 'Research Community')}} Dashboard as a manager. Fill in the verification code, sent to your email, to accept the invitation request.
{{error}}
You have been invited to join {{name}} Monitor Dashboard as a member. Fill in the verification code, sent to your email, to accept the invitation request.
{{error}}
Welcome! You are now a member of the OpenAIRE Monitor Dashboard for the {{name}}! From now on, you will have access to our restricted content.
We are unable to process the request. What happened?
` }) export class RoleVerificationComponent extends BaseComponent implements OnInit, AfterViewInit { @Input() public id: string; @Input() set type(type: string) { this._type = Role.GROUP + type; } @Input() public name: string; @Input() public service: "connect" | "monitor" | "irish" = "monitor"; @Input() public userInfoLinkPrefix = ''; @Input() public userInfoLink = null; @Input() public relativeTo: ActivatedRoute = this._route; public user: User; public verification: any; public code: UntypedFormControl; private _type: string; private paramsSubscription: Subscription; @ViewChild('managerModal') managerModal: AlertModal; @ViewChild('memberModal') memberModal: AlertModal; @ViewChild('errorModal') errorModal: AlertModal; public error: string = null; public loading: boolean = false; public isMember: boolean = false; constructor(protected _route: ActivatedRoute, protected _router: Router, private fb: UntypedFormBuilder, private emailService: EmailService, private userManagementService: UserManagementService, private userRegistryService: UserRegistryService, private clearCacheService: ClearCacheService, private cdr: ChangeDetectorRef) { super(); } ngOnInit() { this.reset(); } ngAfterViewInit() { this.subscriptions.push(this.userManagementService.getUserInfo().subscribe(user => { this.user = user; this.paramsSubscription = this._route.queryParams.subscribe(params => { if (params) { this.cdr.detectChanges(); if(params['verify'] && !this.isMember) { if (this.user) { this.subscriptions.push(this.userRegistryService.getInvitation(params['verify']).subscribe(verification => { this.verification = verification; if (this.user.email === this.verification.email.toLowerCase() && this.id === this.verification.entity && this._type === this.verification.type) { if (this.verification.verificationType === 'manager') { this.openManagerModal(); } else if (this.verification.verificationType === 'member') { this.openMemberModal(); } else { this.openErrorModal(); } } else { this.openErrorModal(); } }, error => { this.openErrorModal(); })); } else { this._router.navigate(['user-info'], { queryParams: { 'errorCode': LoginErrorCodes.NOT_LOGIN, 'redirectUrl': this._router.url }, relativeTo: this.relativeTo }); } } else if(this.isMember) { this.openMemberModal(); } } else { this.isMember = false; this.cdr.detectChanges(); } }); })); } ngOnDestroy() { super.ngOnDestroy(); if (this.paramsSubscription instanceof Subscription) { this.paramsSubscription.unsubscribe(); } } public openManagerModal() { this.error = null; this.managerModal.okButtonLeft = false; this.managerModal.okButtonText = 'Accept'; this.managerModal.stayOpen = true; this.managerModal.cancelButtonText = 'Cancel'; this.managerModal.alertTitle = 'Manager Invitation'; this.managerModal.open(); } public openMemberModal() { this.error = null; if(this.isMember) { this.memberModal.cancelButton = false; this.memberModal.okButtonText = 'Close'; } else { this.memberModal.cancelButton = true; this.memberModal.okButtonText = 'Accept'; } this.memberModal.okButtonLeft = false; this.memberModal.stayOpen = true; this.memberModal.cancelButtonText = 'Cancel'; this.memberModal.alertTitle = 'Member Invitation'; this.cdr.detectChanges(); this.memberModal.open(); } public openErrorModal() { this.error = null; this.errorModal.cancelButton = false; this.errorModal.okButtonText = 'Ok'; this.errorModal.alertTitle = 'Invalid URL'; this.errorModal.open(); } public verifyManager() { this.loading = true; this.subscriptions.push(this.userRegistryService.verify(this.verification.id, this.code.value).subscribe(() => { this.clearCacheService.clearCache('Managers updated'); this.managerModal.cancel(); this.error = null; this.userManagementService.updateUserInfo(() => { if (this.paramsSubscription instanceof Subscription) { this.paramsSubscription.unsubscribe(); } if(this.service === "irish") { this.loading = false; this.userManagementService.login(properties.domain + '/admin/' + this.verification.entity); } else if (this.service === "monitor" ) { this.loading = false; this._router.navigate(['/admin/' + this.verification.entity]); } else { this.subscriptions.push(this.emailService.notifyManagers(this.id, 'manager', Composer.composeEmailToInformOldManagersForTheNewOnes(this.name, this.id)).subscribe(() => { this.subscriptions.push(this.emailService.notifyNewManager(Composer.composeEmailForNewManager(this.id, this.name)).subscribe( () => { this.loading = false; window.location.href = properties.adminPortalURL + '/' + this.verification.entity; }, error1 => { console.error(error1); this.loading = false; window.location.href = properties.adminPortalURL + '/' + this.verification.entity; } )); }, error => { console.error(error); this.loading = false; window.location.href = properties.adminPortalURL + '/' + this.verification.entity; })); } }); }, error => { this.loading = false; this.error = 'The verification code is invalid'; })); } public verifyMember() { this.loading = true; if (!this.isMember) { this.subscriptions.push(this.userRegistryService.verify(this.verification.id, this.code.value, "member").subscribe(() => { this.clearCacheService.clearCache('Members updated'); this.loading = false; this.error = null; this.isMember = true; this.userManagementService.updateUserInfo(() => { if (this.paramsSubscription instanceof Subscription) { this.paramsSubscription.unsubscribe(); } this.cancel(); }); }, error => { this.loading = false; this.error = 'The verification code is invalid'; })); } else { this.memberModal.cancel(); } } public reset() { this.code = this.fb.control('', [Validators.required, Validators.pattern('^[+0-9]{6}$')]); } cancel() { this.isMember = false; this._router.navigate([]); } }