Adds buttons to each input to show/hide passwords
当前为
// ==UserScript==
// @name Password Toggler - view input passwords
// @namespace https://github.com/pckltr/password-toggler
// @version 1.2
// @description Adds buttons to each input to show/hide passwords
// @author pckltr
// @match *://*/*
// ==/UserScript==
(function() {
"use strict";
// get all page inputs
var pageInputs = document.getElementsByTagName("input"),
passwordInputs = [],
buttonStyle = ".password-toggler-button-parent {position: relative; overflow: visible;} .password-toggler-button {top: 50%; right: 8px; position: absolute; cursor: pointer; transform: translateY(-50%); background-size: cover; z-index: 9999999; background: #dcdcdc; border-radius: 100%; background-repeat: no-repeat; background-position: center center; box-sizing: border-box;} .password-toggler-show {background-image: url();} .password-toggler-hide {background-image: url();}";
// add style element in DOM
var style = document.createElement("style");
style.innerHTML = buttonStyle;
document.head.appendChild(style);
var addButtons = function() {
// add password inputs into an array
for (var a = 0; a < pageInputs.length; a++) {
if (pageInputs[a].hasAttribute("type") && pageInputs[a].getAttribute("type") === "password") {
passwordInputs.push(pageInputs[a]);
}
}
// add buttons to each password input
for (var b = 0; b < passwordInputs.length; b++) {
var button = document.createElement("div");
passwordInputs[b].parentElement.className += " password-toggler-button-parent";
passwordInputs[b].parentElement.appendChild(button);
button.setAttribute("style", "height: " + (passwordInputs[b].offsetHeight-8) + "px; width: " + (passwordInputs[b].offsetHeight-8) + "px;");
button.className += "password-toggler-button password-toggler-show";
button.setAttribute("title", "Show password");
}
// get all buttons
var passwordTogglers = document.getElementsByClassName("password-toggler-button");
// toggle password inputs title, type and change button style
function togglePasswords() {
for (var i = 0; i < passwordInputs.length; i++) {
if (passwordInputs[i].type === "password") {
passwordInputs[i].type = "text";
for (var j = 0; j < passwordTogglers.length; j++) {
passwordTogglers[j].title = "Hide password";
passwordTogglers[j].className = "password-toggler-button password-toggler-hide";
}
} else {
passwordInputs[i].type = "password";
for (var k = 0; k < passwordTogglers.length; k++) {
passwordTogglers[k].title = "Show password";
passwordTogglers[k].className = "password-toggler-button password-toggler-show";
}
}
}
}
// add click event to buttons
for (var i = 0; i < passwordTogglers.length; i++) {
passwordTogglers[i].addEventListener("click", togglePasswords, false);
}
// clear inverval
if (pageInputs.length !== 0) {
clearInterval(buttonRepeat);
}
};
// add inverval if inputs don't exist
var buttonRepeat;
if (pageInputs.length === 0) {
buttonRepeat = setInterval(addButtons, 100);
} else {
addButtons();
}
})();