@netgrif/components-core
Version:
Netgrif Application engine frontend core Angular library
119 lines • 17.2 kB
JavaScript
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"]}