Password Toggler - view input passwords

Adds buttons to each input to show/hide passwords

Versão de: 17/09/2024. Veja: a última versão.

// ==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-size: cover;
                z-index: 9999;
                background: #dcdcdc;
                border-radius: 50%;
                background-position: center;
                width: 13px;
                height: 13px;
                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();
  })();