Greasy Fork is available in English.
Toggle dark mode using an icon placed at the bottom left of your screen. Hotkey: Command + Shift + B
// ==UserScript==// @name Dark Reader// @description Toggle dark mode using an icon placed at the bottom left of your screen. Hotkey: Command + Shift + B// @author Schimon Jehudah, Adv.// @namespace i2p.schimon.dimmer// @homepageURL https://gfork.dahi.icu/en/scripts/466058-dark-reader// @supportURL https://greasyfork.org/en/scripts/466058-dark-reader/feedback// @copyright 2023, Schimon Jehudah (http://schimon.i2p)// @license MIT; https://opensource.org/licenses/MIT// @icon  @match *://*/*// @exclude devtools://*// @version 23.06.11// @require https://unpkg.com/[email protected]/darkreader.js// @noframes// @grant GM.getValue// @grant GM.setValue// ==/UserScript==/* TODOToggle color of button.btn.style.filter = 'hue-rotate(500deg)'See https://noscript.net/ oruse a plain character '●'.btn.style.color = 'black' */if (document.doctype == null) { return; }//enable()constnamespace = 'i2p-schimon-dimmer',btn = document.createElement(namespace);// create button(async function createButton() {// create elementdocument.body.append(btn);// set contentbtn.textContent = '🔆';btn.id = namespace;btn.style.all = 'unset';// set positionbtn.style.position = 'fixed';btn.style.bottom = 0;btn.style.left = 0;// set appearancebtn.style.marginTop = '100px';btn.style.marginRight = '10px';btn.style.minWidth = '50px';btn.style.minHeight = '50px';btn.style.fontSize = '20px';btn.style.zIndex = 10000;btn.style.opacity = 0.5;//btn.style.transition = 'all .5s ease .5s';btn.onmouseover = () => {document.getElementById(namespace).style.opacity = 0.9;};btn.onmouseout = () => {document.getElementById(namespace).style.opacity = 0.3;};// center characterbtn.style.justifyContent = 'center';btn.style.alignItems = 'center';btn.style.display = 'flex';// disable selection marksbtn.style.outline = 'none';btn.style.userSelect = 'none';btn.style.cursor = 'default';// set button behaviourbtn.onclick = () => {//btn.onclick = async () => {try {toggle();//await toggle();} catch (err) {toggleByShape();console.warn('No support for Greasemonkey API');console.error(err);}};try {if (await GM.getValue('dimmer')) {enable()} else {disable();}} catch (err) {console.warn('No support for Greasemonkey API');console.error(err);}})();// set hotkeydocument.onkeyup = function(e) {//if (e.ctrlKey && e.shiftKey && e.which == 190) { // Ctrl + Shift + <//if (e.metaKey && e.shiftKey && e.which == 68) { // Command + Shift + Dif (e.metaKey && e.shiftKey && e.which == 66) { // Command + Shift + Btoggle();}};// toggle modeasync function toggle() {if (await GM.getValue('dimmer')) {await GM.setValue('dimmer', false);disable();} else {await GM.setValue('dimmer', true);enable();}}// toggle modefunction toggleByShape() {if (btn.textContent == '🔆') {enable()} else {disable();}}function disable() {DarkReader.disable({brightness: 100,contrast: 90,sepia: 10});btn.textContent = '🔆';//return '🔆';}function enable() {DarkReader.setFetchMethod(window.fetch); // https://eligrey.com/DarkReader.enable({brightness: 100,contrast: 90,sepia: 10});btn.textContent = '🔅';//return '🔅';}// Set mode temporarily per session or until storage is clearedfunction getPreference(key) {return window.localStorage.getItem(key);}function setPreference(key, value) {return window.localStorage.setItem(key, value);}