Password Toggler - view input passwords

Adds buttons to each input to show/hide passwords

当前为 2024-09-17 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name Password Toggler - view input passwords
  3. // @namespace https://github.com/pckltr/password-toggler
  4. // @version 1.4
  5. // @description Adds buttons to each input to show/hide passwords
  6. // @author pckltr
  7. // @match *://*/*
  8. // ==/UserScript==
  9.  
  10. (function () {
  11. "use strict";
  12. const showIcon =
  13. "";
  14. const hideIcon =
  15. "";
  16. const buttonStyle = `
  17. .password-toggler-button-parent {
  18. position: relative;
  19. overflow: visible;
  20. }
  21. .password-toggler-button {
  22. position: absolute;
  23. top: 50%;
  24. right: 8px;
  25. transform: translateY(-50%);
  26. cursor: pointer;
  27. background-size: cover;
  28. z-index: 9999;
  29. background: #dcdcdc;
  30. border-radius: 50%;
  31. background-position: center;
  32. width: 13px;
  33. height: 13px;
  34. display: none;
  35. }
  36. .password-toggler-show { background-image: url(${showIcon}); }
  37. .password-toggler-hide { background-image: url(${hideIcon}); }
  38. `;
  39. // append styles to the document
  40. const styleElement = document.createElement("style");
  41. styleElement.appendChild(document.createTextNode(buttonStyle));
  42. document.head.appendChild(styleElement);
  43. // create toggle button
  44. const createToggleButton = (input) => {
  45. const button = document.createElement("div");
  46. button.className = "password-toggler-button password-toggler-show";
  47. button.title = "Show password - Password Toggler";
  48. button.addEventListener("click", () => togglePassword(input, button));
  49. input.parentElement.classList.add("password-toggler-button-parent");
  50. input.parentElement.appendChild(button);
  51. };
  52. // toggle visibility
  53. const togglePassword = (input, button) => {
  54. const isPassword = input.type === "password";
  55. input.type = isPassword ? "text" : "password";
  56. button.className =
  57. "password-toggler-button " +
  58. (isPassword ? "password-toggler-hide" : "password-toggler-show");
  59. button.title =
  60. (isPassword ? "Hide password" : "Show password") + " - Password Toggler";
  61. };
  62. // add buttons
  63. const addToggleButtons = () => {
  64. document.querySelectorAll("input[type='password']").forEach((input) => {
  65. const button = input.parentElement.querySelector(
  66. ".password-toggler-button"
  67. );
  68. if (!button) {
  69. createToggleButton(input);
  70. } else {
  71. input.addEventListener("focus", () => {
  72. button.style.display = "inline";
  73. });
  74. input.addEventListener("blur", () => {
  75. if (!input.value) {
  76. button.style.display = "none";
  77. }
  78. });
  79. }
  80. });
  81. };
  82. // handle dynamically added password fields
  83. const observer = new MutationObserver(addToggleButtons);
  84. observer.observe(document.body, { childList: true, subtree: true });
  85. // initial run
  86. addToggleButtons();
  87. })();