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.4
// @description Adds buttons to each input to show/hide passwords
// @author pckltr
// @match *://*/*
// ==/UserScript==
(function () {
"use strict";
const showIcon =
"";
const hideIcon =
"";
const buttonStyle = `
.password-toggler-button-parent {
position: relative;
overflow: visible;
}
.password-toggler-button {
position: absolute;
top: 50%;
right: 8px;
transform: translateY(-50%);
cursor: pointer;
background-repeat: no-repeat;
z-index: 9999;
background-color: #dcdcdc;
border-radius: 50%;
background-position: center;
width: 20px;
height: 20px;
display: none;
}
.password-toggler-show { background-image: url(${showIcon}); }
.password-toggler-hide { background-image: url(${hideIcon}); }
`;
// append styles to the document
const styleElement = document.createElement("style");
styleElement.appendChild(document.createTextNode(buttonStyle));
document.head.appendChild(styleElement);
// create toggle button
const createToggleButton = (input) => {
const button = document.createElement("div");
button.className = "password-toggler-button password-toggler-show";
button.title = "Show password - Password Toggler";
button.addEventListener("click", () => togglePassword(input, button));
input.parentElement.classList.add("password-toggler-button-parent");
input.parentElement.appendChild(button);
};
// toggle visibility
const togglePassword = (input, button) => {
const isPassword = input.type === "password";
input.type = isPassword ? "text" : "password";
button.className =
"password-toggler-button " +
(isPassword ? "password-toggler-hide" : "password-toggler-show");
button.title =
(isPassword ? "Hide password" : "Show password") + " - Password Toggler";
};
// add buttons
const addToggleButtons = () => {
document.querySelectorAll("input[type='password']").forEach((input) => {
const button = input.parentElement.querySelector(
".password-toggler-button"
);
if (!button) {
createToggleButton(input);
} else {
input.addEventListener("focus", () => {
button.style.display = "inline";
});
input.addEventListener("blur", () => {
if (!input.value) {
button.style.display = "none";
}
});
}
});
};
// handle dynamically added password fields
const observer = new MutationObserver(addToggleButtons);
observer.observe(document.body, { childList: true, subtree: true });
// initial run
addToggleButtons();
})();