summaryrefslogtreecommitdiff
path: root/frontend/beta/js/Clipperz/PM/Components/PasswordEntropyDisplay.js
blob: b64e0f78125ca1961a833d1ce6ec8da53735ed12 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
/*

Copyright 2008-2013 Clipperz Srl

This file is part of Clipperz, the online password manager.
For further information about its features and functionalities please
refer to http://www.clipperz.com.

* Clipperz is free software: you can redistribute it and/or modify it
  under the terms of the GNU Affero General Public License as published
  by the Free Software Foundation, either version 3 of the License, or 
  (at your option) any later version.

* Clipperz is distributed in the hope that it will be useful, but 
  WITHOUT ANY WARRANTY; without even the implied warranty of 
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  See the GNU Affero General Public License for more details.

* You should have received a copy of the GNU Affero General Public
  License along with Clipperz. If not, see http://www.gnu.org/licenses/.

*/

if (typeof(Clipperz) == 'undefined') { Clipperz = {}; }
if (typeof(Clipperz.PM) == 'undefined') { Clipperz.PM = {}; }
if (typeof(Clipperz.PM.Components) == 'undefined') { Clipperz.PM.Components = {}; }

Clipperz.PM.Components.PasswordEntropyDisplay = function(anElement, args) {
	args = args || {};

//MochiKit.Logging.logDebug(">>> new TextFormField");
	Clipperz.PM.Components.PasswordEntropyDisplay.superclass.constructor.call(this, anElement, args);

	this._wrapperElement = null;
	this._entropyElement = null;

	this.render();
//MochiKit.Logging.logDebug("<<< new TextFormField");
	
	return this;
};

YAHOO.extendX(Clipperz.PM.Components.PasswordEntropyDisplay, Clipperz.PM.Components.BaseComponent, {
	
	'toString': function() {
		return "Clipperz.PM.Components.PasswordEntropyDisplay";
	},

	//-----------------------------------------------------

	'wrapperElement': function() {
		return this._wrapperElement;
	},
	
	'setWrapperElement': function(aValue) {
		this._wrapperElement = aValue;
	},
	
	//-----------------------------------------------------

	'passwordElement': function() {
		return this.element();
	},
	
	//-----------------------------------------------------

	'entropyElement': function() {
		return this._entropyElement;
	},
	
	'setEntropyElement': function(aValue) {
		this._entropyElement = aValue;
	},

	//-----------------------------------------------------

	'render': function() {
		MochiKit.Signal.disconnectAllTo(this);

		this.setWrapperElement(this.element().wrap({tag:'div'}));
		this.setEntropyElement(Clipperz.YUI.DomHelper.append(this.wrapperElement().dom, {tag:'div', cls:'passwordEntropy', html:"&nbsp;"}, true));

//		this.entropyElement().setWidth(this.passwordElement().getWidth());
		this.updateEntropyElement();
		
		MochiKit.Signal.connect(this.element().dom, 'onkeyup', this, 'updateEntropyElement');
		MochiKit.Signal.connect(this.element().dom, 'onchange', this, 'updateEntropyElement');
		MochiKit.Signal.connect(this.element().dom, 'onblur', this, 'updateEntropyElement');
	},

	//-----------------------------------------------------

	'computeEntropyForString': function(aValue) {
		return Clipperz.PM.Crypto.passwordEntropy(aValue);
	},

	//-----------------------------------------------------

	'updateEntropyElement': function(anEvent) {
//MochiKit.Logging.logDebug(">>> PasswordEntropyDisplay.updateEntropyElement");
		var	maxExtent;
		var	entropy;
		
		entropy = Math.min(128, this.computeEntropyForString(this.passwordElement().dom.value));
//MochiKit.Logging.logDebug("--- PasswordEntropyDisplay.updateEntropyElement - entropy: " + entropy);
		this.entropyElement().setStyle('background-position', "0px " + -entropy + "px");
		this.entropyElement().setWidth(this.passwordElement().getWidth() * (entropy/128));
//MochiKit.Logging.logDebug("<<< PasswordEntropyDisplay.updateEntropyElement");
	},
	
	//-----------------------------------------------------
	__syntaxFix__: '__syntaxFix__'
});