passman/js/vendor/ng-password-meter/ng-password-meter.js

119 lines
3.1 KiB
JavaScript
Raw Normal View History

(function () {
2016-09-12 05:40:06 +08:00
'use strict';
/* global _ */
/**
* @ngdoc directive
* @name ngPasswordMeter.directive:ngPassworMeter
* @description
* Simple and elegant password strength meter from the Lifekees
* Password Manager
*/
angular.module('ngPasswordMeter', [])
.directive('ngPasswordMeter', ['$window', function ($window) {
2016-09-12 05:40:06 +08:00
return {
2016-09-12 06:23:06 +08:00
templateUrl: 'views/partials/password-meter.html',
2016-09-12 05:40:06 +08:00
restrict: 'E',
scope: {
password: '=',
strength: '=?',
score: '=?',
2016-09-12 05:40:06 +08:00
},
link: function (scope) {
2016-09-12 05:40:06 +08:00
2016-09-12 06:23:06 +08:00
scope.scoreShown = false;
scope.matchBreakdown = false;
scope.toggleScore = function () {
2016-09-12 06:23:06 +08:00
scope.scoreShown = !scope.scoreShown;
}
2016-09-25 03:03:27 +08:00
jQuery('.match-sequence').hide();
scope.toggleMatchBreakdown = function () {
scope.matchBreakdown = true;
var width = ($window.innerWidth > 420) ? $window.innerWidth * 0.85 : $window.innerWidth * 0.8;
2016-09-25 03:03:27 +08:00
var ms_elem = jQuery('.match-sequence:eq(0)');
ms_elem.dialog({
title: 'Password breakdown',
width: width,
open: function () {
var _totalWidth = 0;
ms_elem.find('.sequence').each(function (key, el) {
2016-09-25 03:03:27 +08:00
_totalWidth += jQuery(el).width() + 20;
});
if (_totalWidth < $window.innerWidth * 0.85) {
2016-09-25 03:03:27 +08:00
ms_elem.width(_totalWidth);
ms_elem.dialog("option", "width", _totalWidth);
jQuery('.ui-dialog').position({
my: "center",
at: "center",
of: window,
collision: "fit",
// Ensure the titlebar is always visible
using: function (pos) {
var topOffset = $(this).css(pos).offset().top;
if (topOffset < 0) {
$(this).css("top", pos.top - topOffset);
}
}
});
}
jQuery('.match-sequence').find('.sequence_container').width(_totalWidth);
},
close: function () {
$('.ui-dialog').remove();
}
})
};
2016-09-12 05:40:06 +08:00
var measureStrength = function (p) {
if (p) {
2016-09-12 06:23:06 +08:00
var _score = zxcvbn(p)
2016-09-12 05:40:06 +08:00
}
2016-09-12 06:23:06 +08:00
return _score;
2016-09-12 05:40:06 +08:00
};
scope.colClass = '';
scope.masterClass = '';
scope.$watch('password', function () {
scope.first = '';
scope.second = '';
scope.third = '';
scope.fourth = '';
scope.message = '';
2016-09-12 05:40:06 +08:00
if (!scope.password) {
scope.masterClass = 'hidden';
return;
}
2016-09-12 06:23:06 +08:00
var _score = measureStrength(scope.password);
scope.score = _score;
scope.strength = _score.score;
2016-09-12 05:40:06 +08:00
scope.masterClass = '';
2016-09-25 02:16:57 +08:00
if (scope.strength <= 1) {
2016-09-12 05:40:06 +08:00
scope.first = 'poor';
scope.message = 'poor';
2016-09-12 06:23:06 +08:00
} else if (scope.strength == 2) {
2016-09-12 05:40:06 +08:00
scope.first = 'weak';
scope.second = 'weak';
scope.message = 'weak';
2016-09-12 06:23:06 +08:00
} else if (scope.strength == 3) {
2016-09-12 05:40:06 +08:00
scope.first = 'good';
scope.second = 'good';
scope.third = 'good';
scope.message = 'good';
2016-09-12 06:23:06 +08:00
} else if (scope.strength == 4) {
2016-09-12 05:40:06 +08:00
scope.first = 'strong';
scope.second = 'strong';
scope.third = 'strong';
scope.fourth = 'strong';
scope.message = 'strong';
2016-09-12 05:40:06 +08:00
}
});
},
};
}]);
2016-09-12 05:40:06 +08:00
})();