Makeshift Theme Switch

Very simple temporary theme switcher for any page

当前为 2025-03-17 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name Makeshift Theme Switch
  3. // @namespace https://mkps.app/
  4. // @version 1.0.3
  5. // @description Very simple temporary theme switcher for any page
  6. // @author MK
  7. // @license MIT
  8. // @match *://*/*
  9. // @icon 
  10. // @grant GM_addStyle
  11. // @grant GM_registerMenuCommand
  12. // ==/UserScript==
  13.  
  14. (() => {
  15. "use strict";
  16.  
  17. const SESSION_STORAGE_KEY = "MK_userscript_makeshiftThemeSwitch_status";
  18.  
  19. const STYLE = `
  20. html, img, canvas, embed, video, object, iframe {
  21. filter: invert(1) hue-rotate(180deg);
  22. }
  23. `;
  24.  
  25. let styleElement = null;
  26.  
  27. function main() {
  28. setState(getStoredIsOn());
  29. GM_registerMenuCommand("Switch theme", switchTheme);
  30. }
  31.  
  32. function switchTheme() {
  33. setState(styleElement == null);
  34. }
  35.  
  36. function setState(on) {
  37. if (styleElement) {
  38. if (!on) {
  39. styleElement.remove();
  40. styleElement = null;
  41. setStoredIsOn(false);
  42. }
  43. } else if (on) {
  44. styleElement = GM_addStyle(STYLE);
  45. setStoredIsOn(true);
  46. }
  47. }
  48.  
  49. function getStoredIsOn() {
  50. return sessionStorage.getItem(SESSION_STORAGE_KEY) == "true";
  51. }
  52.  
  53. function setStoredIsOn(value) {
  54. sessionStorage.setItem(SESSION_STORAGE_KEY, value);
  55. }
  56.  
  57. main();
  58. })();