@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
139 lines • 18.3 kB
JavaScript
import { Component, EventEmitter, Inject, Input, Optional, Output } from '@angular/core';
import { LoadingEmitter } from '../../utility/loading-emitter';
import { take } from 'rxjs/operators';
import { NAE_DEFAULT_MIN_PASSWORD_LENGTH, NAE_MIN_PASSWORD_LENGTH } from "../min-password-length-token";
import * as i0 from "@angular/core";
import * as i1 from "../../authentication/sign-up/services/sign-up.service";
import * as i2 from "../../logger/services/logger.service";
import * as i3 from "@ngx-translate/core";
/**
* Holds the logic that is shared between `RegistrationFormComponent` and `ForgottenPasswordFormComponent`.
*/
export class AbstractRegistrationComponent {
_signupService;
_log;
_translate;
minPasswordLength;
rootFormGroup;
hidePassword;
hideRepeatPassword;
formSubmit;
register;
/**
* Emits whenever the provided token gets resolved as invalid
*/
invalidToken;
_token;
_tokenVerified;
loadingToken;
loadingSubmit;
userEmail;
constructor(_signupService, _log, _translate, minPasswordLength) {
this._signupService = _signupService;
this._log = _log;
this._translate = _translate;
this.minPasswordLength = minPasswordLength;
this.minPasswordLength = minPasswordLength ?? NAE_DEFAULT_MIN_PASSWORD_LENGTH;
this.hidePassword = true;
this.hideRepeatPassword = true;
this.formSubmit = new EventEmitter();
this.register = new EventEmitter();
this.invalidToken = new EventEmitter();
this._tokenVerified = false;
this.loadingToken = new LoadingEmitter(true);
this.loadingSubmit = new LoadingEmitter(false);
}
ngOnDestroy() {
this.formSubmit.complete();
this.register.complete();
this.invalidToken.complete();
this.loadingToken.complete();
this.loadingSubmit.complete();
}
set token(token) {
this._token = token;
if (!this._token) {
this._tokenVerified = false;
return;
}
this.loadingToken.on();
this._signupService.verify(this._token).pipe(take(1)).subscribe(message => {
this._log.info('Token ' + this._token + ' has been successfully verified');
if (message.success) {
this.userEmail = message.success;
}
this._tokenVerified = true;
this.loadingToken.off();
}, (error) => {
this._log.error(error.message);
this._tokenVerified = false;
this.loadingToken.off();
this.invalidToken.emit();
});
}
get token() {
return this._token;
}
get tokenVerified() {
return this._tokenVerified;
}
onSubmit() {
if (!this.rootFormGroup.valid) {
return;
}
const request = this.createRequestBody();
this.formSubmit.emit(request);
if (!this._tokenVerified) {
this.register.emit({ error: 'Provided token ' + this._token + ' is not valid' });
return;
}
request.token = this._token;
this.loadingSubmit.on();
this.callRegistration(request).pipe(take(1)).subscribe(message => {
this.register.emit(message);
this.loadingSubmit.off();
}, error => {
this.register.emit({ error });
this.loadingSubmit.off();
});
}
isFieldValid(formControlName) {
return this.rootFormGroup.get(formControlName).valid;
}
getErrorMessage(formControlName) {
const errors = this.rootFormGroup.get(formControlName).errors;
if (errors === null)
return;
switch (Object.keys(errors)[0]) {
case 'required':
return this._translate.instant('dataField.validations.required');
case 'minlength':
return this._translate.instant('dataField.validations.minLength', { length: this.minPasswordLength });
case 'mismatchedPassword':
return this._translate.instant('forms.register.passwordsMustMatch');
}
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractRegistrationComponent, deps: [{ token: i1.SignUpService }, { token: i2.LoggerService }, { token: i3.TranslateService }, { token: NAE_MIN_PASSWORD_LENGTH, optional: true }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.12", type: AbstractRegistrationComponent, selector: "ncc-abstract-registration", inputs: { token: "token" }, outputs: { formSubmit: "formSubmit", register: "register", invalidToken: "invalidToken" }, ngImport: i0, template: '', isInline: true });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractRegistrationComponent, decorators: [{
type: Component,
args: [{
selector: 'ncc-abstract-registration',
template: ''
}]
}], ctorParameters: () => [{ type: i1.SignUpService }, { type: i2.LoggerService }, { type: i3.TranslateService }, { type: undefined, decorators: [{
type: Optional
}, {
type: Inject,
args: [NAE_MIN_PASSWORD_LENGTH]
}] }], propDecorators: { formSubmit: [{
type: Output
}], register: [{
type: Output
}], invalidToken: [{
type: Output
}], token: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-registration.component.js","sourceRoot":"","sources":["../../../../../../projects/netgrif-components-core/src/lib/forms/models/abstract-registration.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Inject, Input, OnDestroy, Optional, Output} from '@angular/core';\nimport {FormSubmitEvent, HasForm} from '../has-form';\nimport {FormGroup} from '@angular/forms';\nimport {MessageResource} from '../../resources/interface/message-resource';\nimport {LoadingEmitter} from '../../utility/loading-emitter';\nimport {SignUpService} from '../../authentication/sign-up/services/sign-up.service';\nimport {LoggerService} from '../../logger/services/logger.service';\nimport {UserRegistrationRequest} from '../../authentication/sign-up/models/user-registration-request';\nimport {Observable} from 'rxjs';\nimport {TranslateService} from '@ngx-translate/core';\nimport {take} from 'rxjs/operators';\nimport {NAE_DEFAULT_MIN_PASSWORD_LENGTH, NAE_MIN_PASSWORD_LENGTH} from \"../min-password-length-token\";\n\n/**\n * Holds the logic that is shared between `RegistrationFormComponent` and `ForgottenPasswordFormComponent`.\n */\n@Component({\n    selector: 'ncc-abstract-registration',\n    template: ''\n})\nexport abstract class AbstractRegistrationComponent implements HasForm, OnDestroy {\n\n    public rootFormGroup: FormGroup;\n    public hidePassword: boolean;\n    public hideRepeatPassword: boolean;\n\n    @Output() public formSubmit: EventEmitter<FormSubmitEvent>;\n    @Output() public register: EventEmitter<MessageResource>;\n    /**\n     * Emits whenever the provided token gets resolved as invalid\n     */\n    @Output() public invalidToken: EventEmitter<void>;\n\n    private _token: string;\n    private _tokenVerified: boolean;\n    public loadingToken: LoadingEmitter;\n    public loadingSubmit: LoadingEmitter;\n    public userEmail: string;\n\n    protected constructor(protected _signupService: SignUpService,\n                          protected _log: LoggerService,\n                          protected _translate: TranslateService,\n                          @Optional() @Inject(NAE_MIN_PASSWORD_LENGTH) protected minPasswordLength: number | undefined) {\n        this.minPasswordLength = minPasswordLength ?? NAE_DEFAULT_MIN_PASSWORD_LENGTH;\n        this.hidePassword = true;\n        this.hideRepeatPassword = true;\n        this.formSubmit = new EventEmitter<FormSubmitEvent>();\n        this.register = new EventEmitter<MessageResource>();\n        this.invalidToken = new EventEmitter<void>();\n        this._tokenVerified = false;\n        this.loadingToken = new LoadingEmitter(true);\n        this.loadingSubmit = new LoadingEmitter(false);\n    }\n\n    ngOnDestroy(): void {\n        this.formSubmit.complete();\n        this.register.complete();\n        this.invalidToken.complete();\n        this.loadingToken.complete();\n        this.loadingSubmit.complete();\n    }\n\n    @Input()\n    set token(token: string) {\n        this._token = token;\n        if (!this._token) {\n            this._tokenVerified = false;\n            return;\n        }\n        this.loadingToken.on();\n        this._signupService.verify(this._token).pipe(take(1)).subscribe(message => {\n            this._log.info('Token ' + this._token + ' has been successfully verified');\n            if (message.success) {\n                this.userEmail = message.success;\n            }\n            this._tokenVerified = true;\n            this.loadingToken.off();\n        }, (error: Error) => {\n            this._log.error(error.message);\n            this._tokenVerified = false;\n            this.loadingToken.off();\n            this.invalidToken.emit();\n        });\n    }\n\n    get token(): string {\n        return this._token;\n    }\n\n    get tokenVerified(): boolean {\n        return this._tokenVerified;\n    }\n\n    public onSubmit(): void {\n        if (!this.rootFormGroup.valid) {\n            return;\n        }\n        const request = this.createRequestBody();\n        this.formSubmit.emit(request);\n\n        if (!this._tokenVerified) {\n            this.register.emit({error: 'Provided token ' + this._token + ' is not valid'});\n            return;\n        }\n        request.token = this._token;\n        this.loadingSubmit.on();\n        this.callRegistration(request).pipe(take(1)).subscribe(message => {\n            this.register.emit(message);\n            this.loadingSubmit.off();\n        }, error => {\n            this.register.emit({error});\n            this.loadingSubmit.off();\n        });\n    }\n\n    public isFieldValid(formControlName: string): boolean {\n        return this.rootFormGroup.get(formControlName).valid;\n    }\n\n    public getErrorMessage(formControlName: string): string {\n        const errors = this.rootFormGroup.get(formControlName).errors;\n        if (errors === null)\n            return;\n        switch (Object.keys(errors)[0]) {\n            case 'required':\n                return this._translate.instant('dataField.validations.required');\n            case 'minlength':\n                return this._translate.instant('dataField.validations.minLength', {length: this.minPasswordLength});\n            case 'mismatchedPassword':\n                return this._translate.instant('forms.register.passwordsMustMatch');\n        }\n    }\n\n    protected abstract createRequestBody(): UserRegistrationRequest;\n\n    protected abstract callRegistration(requestBody: UserRegistrationRequest): Observable<MessageResource>;\n}\n"]}