2016-10-08 01:56:29 +08:00
|
|
|
(function () {
|
|
|
|
'use strict';
|
2016-09-28 06:14:32 +08:00
|
|
|
/**
|
|
|
|
* @ngdoc directive
|
|
|
|
* @name passmanApp.directive:passwordGen
|
|
|
|
* @description
|
|
|
|
* # passwordGen
|
|
|
|
*/
|
|
|
|
angular.module('passmanApp')
|
2016-10-13 02:12:28 +08:00
|
|
|
.directive('colorFromString', [function () {
|
2016-09-28 06:14:32 +08:00
|
|
|
return {
|
|
|
|
restrict: 'A',
|
|
|
|
scope:{
|
|
|
|
string: '=colorFromString'
|
|
|
|
},
|
2016-10-13 02:12:28 +08:00
|
|
|
link: function (scope, el) {
|
2016-09-28 06:14:32 +08:00
|
|
|
function genColor(str) { // java String#hashCode
|
|
|
|
var hash = 0;
|
|
|
|
for (var i = 0; i < str.length; i++) {
|
|
|
|
hash = str.charCodeAt(i) + ((hash << 5) - hash);
|
|
|
|
}
|
|
|
|
var c = (hash & 0x00FFFFFF)
|
|
|
|
.toString(16)
|
|
|
|
.toUpperCase();
|
|
|
|
|
|
|
|
return '#' + '00000'.substring(0, 6 - c.length) + c;
|
|
|
|
}
|
|
|
|
scope.$watch('string', function(){
|
2016-10-08 01:56:29 +08:00
|
|
|
jQuery(el).css('border-color', genColor(scope.string));
|
|
|
|
});
|
2016-09-28 06:14:32 +08:00
|
|
|
|
|
|
|
}
|
|
|
|
};
|
|
|
|
}]);
|
2016-10-08 01:56:29 +08:00
|
|
|
}());
|