UNPKG

@netgrif/components-core

Version:

Netgrif Application engine frontend core Angular library

119 lines 17.2 kB
import { passwordValidator } from '../models/password.validator'; import { Validators } from '@angular/forms'; import { Component, EventEmitter, Inject, Optional, Output } from '@angular/core'; import { LoadingEmitter } from "../../utility/loading-emitter"; import { take } from "rxjs/operators"; import { encodeBase64 } from '../../utility/base64'; 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 "@angular/forms"; import * as i2 from "../../authentication/profile/services/profile.service"; import * as i3 from "../../user/services/user.service"; import * as i4 from "../../logger/services/logger.service"; import * as i5 from "@ngx-translate/core"; export const OLD_PASSWORD = 'oldPassword'; export const PASSWORD = 'password'; export const CONFIRM_PASSWORD = 'confirmPassword'; export class AbstractChangePasswordComponent { formBuilder; profileService; user; _log; _translate; minPasswordLength; rootFormGroup; hideOldPassword; hidePassword; hideRepeatPassword; formSubmit; changePassword; loadingSubmit; constructor(formBuilder, profileService, user, _log, _translate, minPasswordLength) { this.formBuilder = formBuilder; this.profileService = profileService; this.user = user; this._log = _log; this._translate = _translate; this.minPasswordLength = minPasswordLength; this.minPasswordLength = minPasswordLength ?? NAE_DEFAULT_MIN_PASSWORD_LENGTH; this.hidePassword = true; this.hideOldPassword = true; this.hideRepeatPassword = true; this.formSubmit = new EventEmitter(); this.changePassword = new EventEmitter(); this.loadingSubmit = new LoadingEmitter(false); this.rootFormGroup = formBuilder.group({ oldPassword: ['', [Validators.required, Validators.minLength(1)]], password: ['', [Validators.required, Validators.minLength(this.minPasswordLength)]], confirmPassword: ['', [Validators.required, Validators.minLength(this.minPasswordLength)]] }, { validator: passwordValidator }); } isFieldValid(formControlName) { return this.rootFormGroup.get(formControlName).valid; } createRequestBody() { return { login: this.user.user.email, password: encodeBase64(this.rootFormGroup.controls[OLD_PASSWORD].value), newPassword: encodeBase64(this.rootFormGroup.controls[PASSWORD].value) }; } getErrorMessage(formControlName) { const errors = this.rootFormGroup.get(formControlName).errors; if (errors === null) { return; } switch (Object.keys(errors)[0]) { case 'mismatchedPassword': return this._translate.instant('forms.register.passwordsMustMatch'); case 'minlength': return this._translate.instant('dataField.validations.minLength', { length: this.minPasswordLength }); case 'required': return this._translate.instant('dataField.validations.required'); } } onSubmit() { if (!this.rootFormGroup.valid) { return; } const request = this.createRequestBody(); this.formSubmit.emit(request); this.loadingSubmit.on(); this.profileService.changePassword(request).pipe(take(1)).subscribe(message => { if (message.error) { this.changePassword.emit({ error: message.error }); } else { this.changePassword.emit({ success: message.success }); } this.loadingSubmit.off(); }, error => { this.changePassword.emit({ error }); this.loadingSubmit.off(); }); } ngOnDestroy() { this.formSubmit.complete(); this.changePassword.complete(); this.loadingSubmit.complete(); } static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractChangePasswordComponent, deps: [{ token: i1.FormBuilder }, { token: i2.ProfileService }, { token: i3.UserService }, { token: i4.LoggerService }, { token: i5.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: AbstractChangePasswordComponent, selector: "ncc-abstract-change-password", outputs: { formSubmit: "formSubmit", changePassword: "changePassword" }, ngImport: i0, template: '', isInline: true }); } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: AbstractChangePasswordComponent, decorators: [{ type: Component, args: [{ selector: 'ncc-abstract-change-password', template: '' }] }], ctorParameters: () => [{ type: i1.FormBuilder }, { type: i2.ProfileService }, { type: i3.UserService }, { type: i4.LoggerService }, { type: i5.TranslateService }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [NAE_MIN_PASSWORD_LENGTH] }] }], propDecorators: { formSubmit: [{ type: Output }], changePassword: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"abstract-change-password.component.js","sourceRoot":"","sources":["../../../../../../projects/netgrif-components-core/src/lib/forms/change-password/abstract-change-password.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {passwordValidator} from '../models/password.validator';\nimport {LoggerService} from '../../logger/services/logger.service';\nimport {FormBuilder, FormGroup, Validators} from '@angular/forms';\nimport {MessageResource} from '../../resources/interface/message-resource';\nimport {TranslateService} from '@ngx-translate/core';\nimport {Component, EventEmitter, Inject, OnDestroy, Optional, Output} from '@angular/core';\nimport {FormSubmitEvent, HasForm} from \"../has-form\";\nimport {LoadingEmitter} from \"../../utility/loading-emitter\";\nimport {take} from \"rxjs/operators\";\nimport {UserChangePasswordRequest} from \"../../authentication/profile/models/user-change-password-request\";\nimport {ProfileService} from \"../../authentication/profile/services/profile.service\";\nimport {UserService} from \"../../user/services/user.service\";\nimport {encodeBase64} from '../../utility/base64';\nimport {NAE_DEFAULT_MIN_PASSWORD_LENGTH, NAE_MIN_PASSWORD_LENGTH} from \"../min-password-length-token\";\n\nexport const OLD_PASSWORD = 'oldPassword';\nexport const PASSWORD = 'password';\nexport const CONFIRM_PASSWORD = 'confirmPassword';\n\n@Component({\n    selector: 'ncc-abstract-change-password',\n    template: ''\n})\nexport abstract class AbstractChangePasswordComponent implements HasForm, OnDestroy {\n\n    public rootFormGroup: FormGroup;\n    public hideOldPassword: boolean;\n\n    public hidePassword: boolean;\n    public hideRepeatPassword: boolean;\n\n    @Output() public formSubmit: EventEmitter<FormSubmitEvent>;\n    @Output() public changePassword: EventEmitter<MessageResource>;\n\n    public loadingSubmit: LoadingEmitter;\n\n    protected constructor(protected formBuilder: FormBuilder,\n                          protected profileService: ProfileService,\n                          protected user: UserService,\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.hideOldPassword = true;\n        this.hideRepeatPassword = true;\n        this.formSubmit = new EventEmitter<FormSubmitEvent>();\n        this.changePassword = new EventEmitter<MessageResource>();\n        this.loadingSubmit = new LoadingEmitter(false);\n        this.rootFormGroup = formBuilder.group({\n            oldPassword: ['', [Validators.required, Validators.minLength(1)]],\n            password: ['', [Validators.required, Validators.minLength(this.minPasswordLength)]],\n            confirmPassword: ['', [Validators.required, Validators.minLength(this.minPasswordLength)]]\n        }, {validator: passwordValidator});\n    }\n\n\n    public isFieldValid(formControlName: string): boolean {\n        return this.rootFormGroup.get(formControlName).valid;\n    }\n\n    protected createRequestBody(): UserChangePasswordRequest {\n        return {\n            login: this.user.user.email,\n            password: encodeBase64(this.rootFormGroup.controls[OLD_PASSWORD].value),\n            newPassword: encodeBase64(this.rootFormGroup.controls[PASSWORD].value)\n        };\n    }\n\n    public getErrorMessage(formControlName: string): string {\n        const errors = this.rootFormGroup.get(formControlName).errors;\n        if (errors === null) {\n            return;\n        }\n        switch (Object.keys(errors)[0]) {\n            case 'mismatchedPassword':\n                return this._translate.instant('forms.register.passwordsMustMatch');\n            case 'minlength':\n                return this._translate.instant('dataField.validations.minLength', {length: this.minPasswordLength});\n            case 'required':\n                return this._translate.instant('dataField.validations.required');\n        }\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        this.loadingSubmit.on();\n        this.profileService.changePassword(request).pipe(take(1)).subscribe(message => {\n            if (message.error) {\n                this.changePassword.emit({error: message.error});\n            } else {\n                this.changePassword.emit({success: message.success});\n            }\n            this.loadingSubmit.off();\n        }, error => {\n            this.changePassword.emit({error});\n            this.loadingSubmit.off();\n        });\n    }\n\n    ngOnDestroy(): void {\n        this.formSubmit.complete();\n        this.changePassword.complete();\n        this.loadingSubmit.complete();\n    }\n\n}\n"]}