primeng
Version:
[](https://opensource.org/licenses/MIT) [](https://badge.fury.io/js/primeng) [ || function (decorators, target, key, desc) {
var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
return c > 3 && r && Object.defineProperty(target, key, r), r;
};
import { NgModule, Directive, ElementRef, HostListener, Input, OnDestroy, DoCheck, NgZone } from '@angular/core';
import { CommonModule } from '@angular/common';
import { DomHandler } from 'primeng/dom';
var Password = /** @class */ (function () {
function Password(el, zone) {
this.el = el;
this.zone = zone;
this.promptLabel = 'Enter a password';
this.weakLabel = 'Weak';
this.mediumLabel = 'Medium';
this.strongLabel = 'Strong';
this.feedback = true;
}
Object.defineProperty(Password.prototype, "showPassword", {
set: function (show) {
this.el.nativeElement.type = show ? 'text' : 'password';
},
enumerable: true,
configurable: true
});
Password.prototype.ngDoCheck = function () {
this.updateFilledState();
};
//To trigger change detection to manage ui-state-filled for material labels when there is no value binding
Password.prototype.onInput = function (e) {
this.updateFilledState();
};
Password.prototype.updateFilledState = function () {
this.filled = this.el.nativeElement.value && this.el.nativeElement.value.length;
};
Password.prototype.createPanel = function () {
this.panel = document.createElement('div');
this.panel.className = 'ui-password-panel ui-widget ui-state-highlight ui-corner-all';
this.meter = document.createElement('div');
this.meter.className = 'ui-password-meter';
this.info = document.createElement('div');
this.info.className = 'ui-password-info';
this.info.textContent = this.promptLabel;
this.panel.appendChild(this.meter);
this.panel.appendChild(this.info);
this.panel.style.minWidth = DomHandler.getOuterWidth(this.el.nativeElement) + 'px';
document.body.appendChild(this.panel);
};
Password.prototype.onFocus = function (e) {
var _this = this;
if (this.feedback) {
if (!this.panel) {
this.createPanel();
}
this.panel.style.zIndex = String(++DomHandler.zindex);
this.zone.runOutsideAngular(function () {
setTimeout(function () {
DomHandler.addClass(_this.panel, 'ui-password-panel-visible');
DomHandler.removeClass(_this.panel, 'ui-password-panel-hidden');
}, 1);
DomHandler.absolutePosition(_this.panel, _this.el.nativeElement);
});
}
};
Password.prototype.onBlur = function (e) {
var _this = this;
if (this.feedback) {
DomHandler.addClass(this.panel, 'ui-password-panel-hidden');
DomHandler.removeClass(this.panel, 'ui-password-panel-visible');
this.zone.runOutsideAngular(function () {
setTimeout(function () {
_this.ngOnDestroy();
}, 150);
});
}
};
Password.prototype.onKeyup = function (e) {
if (this.feedback) {
var value = e.target.value, label = null, meterPos = null;
if (value.length === 0) {
label = this.promptLabel;
meterPos = '0px 0px';
}
else {
var score = this.testStrength(value);
if (score < 30) {
label = this.weakLabel;
meterPos = '0px -10px';
}
else if (score >= 30 && score < 80) {
label = this.mediumLabel;
meterPos = '0px -20px';
}
else if (score >= 80) {
label = this.strongLabel;
meterPos = '0px -30px';
}
}
this.meter.style.backgroundPosition = meterPos;
this.info.textContent = label;
}
};
Password.prototype.testStrength = function (str) {
var grade = 0;
var val;
val = str.match('[0-9]');
grade += this.normalize(val ? val.length : 1 / 4, 1) * 25;
val = str.match('[a-zA-Z]');
grade += this.normalize(val ? val.length : 1 / 2, 3) * 10;
val = str.match('[!@#$%^&*?_~.,;=]');
grade += this.normalize(val ? val.length : 1 / 6, 1) * 35;
val = str.match('[A-Z]');
grade += this.normalize(val ? val.length : 1 / 6, 1) * 30;
grade *= str.length / 8;
return grade > 100 ? 100 : grade;
};
Password.prototype.normalize = function (x, y) {
var diff = x - y;
if (diff <= 0)
return x / y;
else
return 1 + 0.5 * (x / (x + y / 4));
};
Object.defineProperty(Password.prototype, "disabled", {
get: function () {
return this.el.nativeElement.disabled;
},
enumerable: true,
configurable: true
});
Password.prototype.ngOnDestroy = function () {
if (this.panel) {
document.body.removeChild(this.panel);
this.panel = null;
this.meter = null;
this.info = null;
}
};
Password.ctorParameters = function () { return [
{ type: ElementRef },
{ type: NgZone }
]; };
__decorate([
Input()
], Password.prototype, "promptLabel", void 0);
__decorate([
Input()
], Password.prototype, "weakLabel", void 0);
__decorate([
Input()
], Password.prototype, "mediumLabel", void 0);
__decorate([
Input()
], Password.prototype, "strongLabel", void 0);
__decorate([
Input()
], Password.prototype, "feedback", void 0);
__decorate([
Input()
], Password.prototype, "showPassword", null);
__decorate([
HostListener('input', ['$event'])
], Password.prototype, "onInput", null);
__decorate([
HostListener('focus', ['$event'])
], Password.prototype, "onFocus", null);
__decorate([
HostListener('blur', ['$event'])
], Password.prototype, "onBlur", null);
__decorate([
HostListener('keyup', ['$event'])
], Password.prototype, "onKeyup", null);
Password = __decorate([
Directive({
selector: '[pPassword]',
host: {
'[class.ui-inputtext]': 'true',
'[class.ui-corner-all]': 'true',
'[class.ui-state-default]': 'true',
'[class.ui-widget]': 'true',
'[class.ui-state-filled]': 'filled'
}
})
], Password);
return Password;
}());
export { Password };
var PasswordModule = /** @class */ (function () {
function PasswordModule() {
}
PasswordModule = __decorate([
NgModule({
imports: [CommonModule],
exports: [Password],
declarations: [Password]
})
], PasswordModule);
return PasswordModule;
}());
export { PasswordModule };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"password.js","sourceRoot":"ng://primeng/password/","sources":["password.ts"],"names":[],"mappings":"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","sourcesContent":["import {NgModule,Directive,ElementRef,HostListener,Input,OnDestroy,DoCheck,NgZone} from '@angular/core';\nimport {CommonModule} from '@angular/common';\nimport {DomHandler} from 'primeng/dom';\n\n@Directive({\n    selector: '[pPassword]',\n    host: {\n        '[class.ui-inputtext]': 'true',\n        '[class.ui-corner-all]': 'true',\n        '[class.ui-state-default]': 'true',\n        '[class.ui-widget]': 'true',\n        '[class.ui-state-filled]': 'filled'\n    }\n})\nexport class Password implements OnDestroy,DoCheck {\n\n    @Input() promptLabel: string = 'Enter a password';\n\n    @Input() weakLabel: string = 'Weak';\n\n    @Input() mediumLabel: string = 'Medium';\n\n    @Input() strongLabel: string = 'Strong';\n    \n    @Input() feedback: boolean = true;\n\n    @Input() set showPassword(show: boolean) {\n        this.el.nativeElement.type = show ? 'text' : 'password';\n    }\n    \n    panel: HTMLDivElement;\n    \n    meter: any;\n    \n    info: any;\n    \n    filled: boolean;\n    \n    constructor(public el: ElementRef, public zone: NgZone) {}\n    \n    ngDoCheck() {\n        this.updateFilledState();\n    }\n    \n    //To trigger change detection to manage ui-state-filled for material labels when there is no value binding\n    @HostListener('input', ['$event']) \n    onInput(e) {\n        this.updateFilledState();\n    }\n    \n    updateFilledState() {\n        this.filled = this.el.nativeElement.value && this.el.nativeElement.value.length;\n    }\n\n    createPanel() {\n        this.panel = document.createElement('div');\n        this.panel.className = 'ui-password-panel ui-widget ui-state-highlight ui-corner-all';\n        this.meter = document.createElement('div');\n        this.meter.className = 'ui-password-meter';\n        this.info = document.createElement('div');\n        this.info.className = 'ui-password-info';\n        this.info.textContent = this.promptLabel;\n        this.panel.appendChild(this.meter);\n        this.panel.appendChild(this.info);\n        this.panel.style.minWidth = DomHandler.getOuterWidth(this.el.nativeElement) + 'px';\n        document.body.appendChild(this.panel);\n    }\n        \n    @HostListener('focus', ['$event']) \n    onFocus(e) {\n        if (this.feedback) {\n            if (!this.panel) {\n                this.createPanel();\n            }\n    \n            this.panel.style.zIndex = String(++DomHandler.zindex);\n            this.zone.runOutsideAngular(() => {\n                setTimeout(() => {\n                    DomHandler.addClass(this.panel, 'ui-password-panel-visible');\n                    DomHandler.removeClass(this.panel, 'ui-password-panel-hidden');\n                }, 1);\n                DomHandler.absolutePosition(this.panel, this.el.nativeElement);\n            });\n        }\n    }\n    \n    @HostListener('blur', ['$event']) \n    onBlur(e) {   \n        if (this.feedback) {\n            DomHandler.addClass(this.panel, 'ui-password-panel-hidden');\n            DomHandler.removeClass(this.panel, 'ui-password-panel-visible');\n\n            this.zone.runOutsideAngular(() => {\n                setTimeout(() => {\n                    this.ngOnDestroy();\n                }, 150);\n            });\n        }     \n    }\n    \n    @HostListener('keyup', ['$event'])\n    onKeyup(e) {\n        if (this.feedback) {\n            let value = e.target.value,\n            label = null,\n            meterPos = null;\n\n            if (value.length === 0) {\n                label = this.promptLabel;\n                meterPos = '0px 0px';\n            }\n            else {\n                var score = this.testStrength(value);\n\n                if (score < 30) {\n                    label = this.weakLabel;\n                    meterPos = '0px -10px';\n                }\n                else if (score >= 30 && score < 80) {\n                    label = this.mediumLabel;\n                    meterPos = '0px -20px';\n                } \n                else if (score >= 80) {\n                    label = this.strongLabel;\n                    meterPos = '0px -30px';\n                }\n            }\n\n            this.meter.style.backgroundPosition = meterPos;\n            this.info.textContent = label;\n        }\n    }\n    \n    testStrength(str: string) {\n        let grade: number = 0;\n        let val;\n\n        val = str.match('[0-9]');\n        grade += this.normalize(val ? val.length : 1/4, 1) * 25;\n\n        val = str.match('[a-zA-Z]');\n        grade += this.normalize(val ? val.length : 1/2, 3) * 10;\n\n        val = str.match('[!@#$%^&*?_~.,;=]');\n        grade += this.normalize(val ? val.length : 1/6, 1) * 35;\n\n        val = str.match('[A-Z]');\n        grade += this.normalize(val ? val.length : 1/6, 1) * 30;\n\n        grade *= str.length / 8;\n\n        return grade > 100 ? 100 : grade;\n    }\n    \n    normalize(x, y) {\n        let diff = x - y;\n\n        if (diff <= 0)\n            return x / y;\n        else\n            return 1 + 0.5 * (x / (x + y/4));\n    }\n    \n    get disabled(): boolean {\n        return this.el.nativeElement.disabled;\n    }\n    \n    ngOnDestroy() {\n        if (this.panel) {\n            document.body.removeChild(this.panel);\n            this.panel = null;\n            this.meter = null;\n            this.info = null;\n        }\n    }\n}\n\n@NgModule({\n    imports: [CommonModule],\n    exports: [Password],\n    declarations: [Password]\n})\nexport class PasswordModule { }\n"]}