UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

139 lines 18.3 kB
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"]}